二、Nginx常用模块-动态负载均衡(nginx-upsync-module )

简介

nginx-upsync-module 提供了动态的负载均衡, 动态更新上游的服务器不需要 reload nginx , 它的功能是拉取 consul 的后端 server 的列表, 并更新Nginx 的路由信息。
此模块不依赖于任何第三方模块。
consul 作为 Nginx 的 db, 利用 consul 的 KV 服务, 每个 Nginx work 进程独立的去拉取各个upstream 的配置, 并更新各自的路由。

nginx -s reload 是平滑重启, 不会强制结束正在工作的连接, 需要等所有连接都结束才会重启。 想象一个场景上线繁忙, 想要多添加几台服务器处理更多的流量

改配置文件并重新启动 Nginx 可能并不总是很方便。 例如, 当遇到大流量和高负载, 重启 Nginx 并在此时重新加载配置会进一步增加系统负载, 并可能暂时降低性能

nginx安装第三方模块nginx-upsync-module

nginx安装第三方模块的半自动平滑升级

下载到/root/download/
wget https://github.com/weibocom/nginx-upsync-module/archive/v2.1.1.tar.gz

tar zxvf v2.1.1.tar.gz 生成了目录 nginx-upsync-module-2.1.1
cd /root/download/openresty-1.15.8.2
./configure --add-module=/root/download/nginx-upsync-module-2.1.1
make 
cd /usr/local/openresty/nginx/sbin 
mv nginx nginx.old
cp /root/download/openresty-1.15.8.2/build/nginx-1.15.8/objs/nginx /usr/local/openresty/nginx/sbin/

执行:./nginx -t
nginx: the configuration file /home/app/openresty/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /home/app/openresty/nginx/conf/nginx.conf test is successful
测试成功

启动新的进程,关掉旧的
让nginx把nginx.pid改成nginx.pid.oldbin 跟着启动新的nginx
# kill -USR2 `cat /home/app/openresty/nginx/nginx.pid`
退出旧的nignx
# kill -QUIT `cat /home/app/openresty/nginx/nginx.pid.oldbin`

#升级完成

consul安装

consul
wget https://releases.hashicorp.com/consul/1.6.2/consul_1.6.2_linux_amd64.zip
unzip consul_1.6.2_linux_amd64.zip
mv consul /usr/local/bin/ 

运行

consul agent  -server  -bootstrap-expect 1 -data-dir /tmp/consul -node=ali      -bind=172.17.0.10    -ui   -client=0.0.0.0

参数说明

参数含义:
agent  
-server表示启动的是一个服务
-bootstrap-expect 1 表示等待多少个节点再启动,这里1个,就是自己一个就启动了
-node=texun_1 就是给consul服务起个别名为ali_1
-bind=172.17.114.76  绑定内网ip
-data-dir /opt/data1  数据存储目录为/opt/data1
 -ui 启动默认ui界面
 -client  consul绑定在哪个client地址上,这个地址提供HTTP、DNS、RPC等服务,默认是127.0.0.1,可指定允许客户端使用什么ip去访问

命令

curl -X PUT -d '{}' http://127.0.0.1:8500/v1/kv/upstreams/backend/127.0.0.1:9502

curl -X PUT -d '{"weight":1,"max_fails":2,"fail_timeout":10}' http://127.0.0.1:8500/v1/kv/upstreams/backend/127.0.0.1:9502


查看所有已经存储的k/v
curl http://127.0.0.1:8500/v1/kv/?recurse

删除 curl -X DELETE http://127.0.0.1:8500/

配置动态负载均衡

只需要修改 upstream backend

upstream backend {
        upsync 127.0.0.1:8500/v1/kv/upstreams/backend upsync_timeout=6m upsync_interval=500ms upsync_type=consul
        strong_dependency=off;
        upsync_dump_path /usr/local/openresty/nginx/conf/servers_test.conf; #生成配置文件
        include /usr/local/openresty/nginx/conf/servers_test.conf; #包含生成的配置文件
       # server 127.0.0.1:9501;
        #server 127.0.0.1:9501 weight=50;
        #server 127.0.0.1:9502 weight=30;
    }

重启nginx后,就可以使用下面的命令动态增删service

新增
curl -X PUT -d '{"weight":1,"max_fails":2,"fail_timeout":10}' http://127.0.0.1:8500/v1/kv/upstreams/backend/127.0.0.1:9502

删除 
curl -X DELETE http://127.0.0.1:8500/v1/kv/upstreams/backend/127.0.0.1:9502

查看所有已经存储的k/v
curl http://127.0.0.1:8500/v1/kv/?recurse

注意事项:
1.servers_test.conf必须存在
2.upstream backend必须至少包含一个services

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

InterestingFigure

迈克 Let's Go

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值