【平台中间件】Nginx安装配置,实现版本更新不影响服务访问
为什么要做负载均衡?
Nginx安装
获取安装包
使用如下的命令可以在nginx官网获取安装包,博主获取的是nginx-1.11.5这个版本
wget http://nginx.org/download/nginx-1.11.5.tar.gz
解压安装包
tar -zxvf nginx-1.11.5.tar.gz
切换到 nginx-1.11.5 目录
执行 nginx下的configure进行配置
./configure
解决 checking for C compiler ... not found 错误
./configure: error: C compiler cc is not found
原因定位:没有安装gcc
解决方法:使用root用户 执行 yum install gcc
gcc安装成功界面:
再次执行 ./configure
解决the HTTP rewrite module requires the PCRE library. 错误
./configure: error: the HTTP rewrite module requires the PCRE library.
原因: 缺少pcre包
解决方法:yum -y install pcre-devel 进行安装
安装后再次执行./configure
解决:./configure: error: the HTTP cache module requires md5 functions from OpenSSL library错误
原因:需要进行md5加密操作的没有找到md5模块
解决方法:yum -y install openssl openssl-devel 安装openssl加密模块
再次执行./configure,终于成功了
然后再执行 make &&make install,执行过程没有报错,终于安装成功了
启动
nginx的启动目录在 /usr/local/nginx/sbin 下
直接进入该安装目录下,输入命令 ./nginx -t 即可启动
执行 ./nginx -s reload 可以进行重启操作
配置负债均衡
修改监听端口
nginx的配置在/usr/local/nginx 目录下的conf中
vi /usr/local/nginx/conf/nginx.conf
配置负债均衡
添加如下两部分:
upstream mysite{ server 10.1.2.**:8085 weight=1; server 10.1.2.**:8080 weight=2; } server { listen 8090; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; location / { root html; index index.html index.htm; proxy_pass http://mysite; }
其中 server 10.1.2.**:8085 10.1.2.**:8080 为在本地配置的两个tomcat服务器监听的IP和端口
weight 为配置的权重,可以让用户的访问,按照 1:2 的比例进行分配,实现 不同服务器分配不同的数量的用户
验证访问nginx
访问 nginx所在及其监听的端口,比如: 10.1.2.**:8090,点击刷新,就可以看到 轮询访问了 10.1.2.**:8085 10.1.2.**:8080两个静态页面,而且页面按照我们前面配置分配的权重比例呈现,
即返回一次8085的信息之后会返回两次8080的信息。
具体页面信息如下:
其实 Nginx 是支持你去更新其中一个服务器的时候,把请求都转发到另一台服务器的,它监测到这个服务器挂掉了就不会进行请求分发。但是Nginx 的upstream配置中有种更好的方式,就是配置备份服务器 -- backup。
配置backup
现在我们增加一个 Tomcat服务器3,然后做如下的配置:
说明:
- 192.168.198.128:8080服务器下面会称为服务器1,每五次请求会到这里一次;
- 192.168.198.128:8090服务器下面会称为服务器2,每五次请求会到这里四次;
- 192.168.198.128:8091服务器下面会称为服务器3,即备份服务器。
服务器1、服务器2和服务器3都正常启动,我们刷新页面,请求会按照权重规则请求服务器1和服务器2,并不会请求服务器3(备份服务器)。
接下来我们把服务器1停掉,服务器2和服务器3都正常启动,我刷新页面,这个时候所有请求都到了服务器2,也并不会请求服务器3(备份服务器)。
然后我们把 服务器1、服务器2都停掉,服务器3正常启动,刷新页面,所有请求都转发到了服务器3(备份服务器),看图片:
最后,我们次依次启动 服务器1和服务器2,所有请求都又按照权重规则分配了。 在你所有正常服务器都挂掉时,系统依然高可用,这就是备份服务器的用处 !
可以实际应用于上线验证,我们在上线之前可以先在备份服务器做好验证之后在无缝切换服务器,在不影响线上原服务的情况完成代码的更新。
合抱之木,生于毫末;九层之台,起于累土;千里之行,始于足下。