利用consul+nginx-upsync实现动态负载
这是前一段时间学习的课程上面的,自己实际操作了一下,详细操作及说明如下。
如果Nginx遇到大流量和高负载,修改配置文件重启可能并不总是那么方便,因为恢复Nginx并重载配置会进一步增加系统负载,并很可能暂时降低性能。而一个个修改配置文件也是很容易出错和费时间的操作。
这时候不妨试试consul+nginx-upsync-module实现Nginx的动态负载。
nginx-upsync-module
nginx-upsync-module 提供了动态的负载均衡,它可以从consul或etcd同步upstreams,动态修改后端服务器属性(weight,max_fails,down…),而不需要重新加载nginx。这样我们通过它实现平滑伸缩,而不严重地影响性能。
利用docker安装
我已经基于centos7构建了一个镜像 13sai/nginx-lua-upsync ,你可以使用下面的命令启动一个容器
docker run -itd –name=nginx-upsync -p 8008:80 -p 9501:9501 -p 9502:9502 -p 9503:9503 -p 8500:8500 13sai/nginx-lua-upsync
当然,你也可以不使用docker自行搭建,添加nginx-upsync-module模块可以参考nginx模块lua模块。
进入容器配置
docker exec -it nginx-upsync /bin/bash
cd /usr/local/nginx/conf
echo “server host.docker.internal:9501 weight=1 fail_timeout=10 max_fails=3;” >> servers.conf
vi nginx.conf
1 |
|
upsync语法说明
1 |
|
注意下面这个文件必须要有,文件路径和名称可以自定义,nginx-upsync-module会将负载信息缓存到此文件,否则Nginx启动会报错。
1 |
|
重启nginx
/usr/local/nginx/sbin/nginx -t
/usr/local/nginx/sbin/nginx -s reload
这里虽然我们还未启动consul,但没有什么影响,upsync会去拉取,也必然会失败,servers.conf就不会更新,Nginx的error日志会有信息。
利用swoole启动3个http服务
1 |
|
consul安装
这里consul只做一个kv存储,我自己也是第一次用,就不去做过多介绍了。
解压到你需要的目录,主要也就是一个consul可执行文件。(这里我装在我的电脑,而不是刚才的docker容器)
命令可看文档:Consul 简介和快速入门
启动:
nohup ./consul agent -dev &
为了方便,我们也没有启动集群,生产环境建议使用consul集群。
UI查看
查看节点
./consul members
curl 127.0.0.1:8500/v1/catalog/nodes
查看kv值
添加
curl -X PUT -d ‘{“weight”:20,”max_fails”:2,”fail_timeout”:5}’ http://127.0.0.1:8500/v1/kv/upstreams/test-server/192.168.x.xxx:9502
此处192.168.x.xxx是因为我创建的docker容器的宿主机ip。
删除
curl -X DELETE http://127.0.0.1:8500/v1/kv/upstreams/test-server/192.168.x.xxx:9502
我们可以通过添加和删除来测试,查看http://127.0.0.1:8008/来查看输出,也可以看看Nginx里的配置文件servers.conf,你会看到你操作consul,会动态改变Nginx的upstream,这样就实现了Nginx的动态扩容。
对consul和docker的学习还不够深入,文中如有错误,欢迎指正交流。