Nginx服务器
1.Nginx服务器
Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器。由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5万并发链接,并且cpu、内存等资源消耗却非常低,运行非常稳定。
2.应用场景
- 作为Http服务器:可以作为网页静态页面服务器.
- 虚拟主机:一台服务器可以虚拟出多个网站.
- 反向代理,负载均衡:当网站访问量达到一定程度时,单台服务器不能满足时,可以利用Nginx做反向代理服务器,多台服务器可以平均分担负载.
3.Nginx的安装
下载nginx:
官方网站:
环境
1、需要安装gcc的环境。yum install gcc-c++
2、第三方的开发包。
PCRE
PCRE(Perl Compatible Regular Expressions)是一个Perl库,包括 perl 兼容的正则表达式库。nginx的http模块使用pcre来解析正则表达式,所以需要在linux上安装pcre库。
yum install -y pcre pcre-devel
注:pcre-devel是使用pcre开发的一个二次开发库。nginx也需要此库。
zlib
zlib库提供了很多种压缩和解压缩的方式,nginx使用zlib对http包的内容进行gzip,所以需要在linux上安装zlib库。
yum install -y zlib zlib-devel
openssl
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。
nginx不仅支持http协议,还支持https(即在ssl协议上传输http),所以需要在linux安装openssl库。
yum install -y openssl openssl-devel
安装
第一步:把nginx的源码包上传到linux系统
第二步:解压缩
[root@localhost ~]# tar zxf nginx-1.8.0.tar.gz
第三步:使用configure命令创建一makeFile文件。
./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi
注意:启动nginx之前,上边将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录
[root@localhost sbin]# mkdir /var/temp/nginx/client -p
第四步:make
第五步:make install
启动和重启
进入sbin目录
[root@localhost sbin]# ./nginx
关闭nginx:
[root@localhost sbin]# ./nginx -s stop
推荐使用:
[root@localhost sbin]# ./nginx -s quit
重启nginx:
1、先关闭后启动。
2、刷新配置文件:
[root@localhost sbin]# ./nginx -s reload
4.虚拟主机的配置
在一台服务器可以启动多个网站.
可以通过端口或者域名来区分.不同的站点.
1.通过端口来区分不同的虚拟主机.
进入/conf/Nginx.conf .来修改配置,增加一个server就是一个不同的虚拟主机,这种配置方法是来用端口号来去分不同的虚拟主机,不常用,其中,location则为静态页面所在的位置.
server {
listen 81;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html81;
index index.html index.htm;
}
}
2.通过域名来区分不同的虚拟主机.(静态页面)
一个域名对应一个ip地址,一个ip地址可以被多个域名绑定。
本地测试可以修改hosts文件(C:\Windows\System32\drivers\etc)
在其中可以配置域名和ip地址的映射关系,如果配置了,则不走DNS服务器.
server {
listen 80;
server_name www.taobao.com;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html-taobao;
index index.html index.htm;
}
}
server {
listen 80;
server_name www.baidu.com;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
root html-baidu;
index index.html index.htm;
}
}
其中www.taobao.com www.baidu.com为Nginx的IP绑定的域名.可以通过域名的不同来区分主机
5.Nginx的反向代理.
1.Nginx实现反向代理的原理.
假设有绑定两个不同的域名在Nginx服务器的ip上,当访问不同的域名时,显示不同的页面,在这里Nginx服务器作为一个代理服务器,负责转发到内部不同的tomcat或者别的服务器.

2.反向代理服务器的测试.
1.安装两个tomcat,运行在8080和8081端口
2.启动tomcat服务器
3.进行反向代理的配置.
upstream tomcat1 {
server 192.168.25.148:8080;
}
server {
listen 80;
server_name www.sina.com.cn;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
proxy_pass http://tomcat1;
index index.html index.htm;
}
}
upstream tomcat2 {
server 192.168.25.148:8081;
}
server {
listen 80;
#配置域名 host文件下配置
server_name www.sohu.com;
#charset koi8-r;
#access_log logs/host.access.log main;
location / {
#代理
proxy_pass http://tomcat2;
index index.html index.htm;
}
}
在hosts文件中添加域名和ip的映射关系
192.168.25.148 www.sina.com.cn
192.168.25.148 www.sohu.com
3.负载均衡
如果一个服务由多条服务器提供,需要把负载分配到不同的服务器处理,需要负载均衡。
upstream tomcat2 {
server 192.168.25.148:8081;
server 192.168.25.148:8082;
}
可以根据服务器的实际情况调整服务器权重。权重越高分配的请求越多,权重越低,请求越少。默认是都是1
upstream tomcat2 {
server 192.168.25.148:8081;
server 192.168.25.148:8082 weight=2;
}
6. Nginx的高可用.
keepalived+nginx实现主备
参考QQ云文件 keepalived高可用

浙公网安备 33010602011771号