nginx_upstream_check模块可以根据指定的检查周期与参数定期检查upstream后端的存活情况,若判定某一后端检查失败,则标记为"DOWN"状态,访问流量则不再流向该失败后端服务。
nginx添加nginx_upstream_check模块:
1:下载模块。git地址如下:https://github.com/yaoweibin/nginx_upstream_check_module
# unzip nginx_upstream_check_module-master.zip
2:根据nginx版本打补丁(我这里使用的是nginx-1.12.1版本)。
# cd nginx-1.12.1 # patch -p1 < /usr/local/src/nginx_upstream_check_module-master/check_1.12.1+.patch
3:编译、安装nginx,添加上nginx_upstrem_check模块。
# ./configure --prefix=/usr/local/nginx --user=nobody --group=nobody --add-module=/usr/local/src/nginx_upstream_check_module-master/ # make && make install
4:为一个upstream服务组配置后端检查。
upstream xxxxxx { server 172.17.1.164:8080; server 172.17.3.164:8080; check interval=2000 rise=2 fall=2 timeout=1000 type=http; check_http_send "HEAD / HTTP/1.0\r\n\r\n"; check_http_expect_alive http_2xx http_3xx http_4xx; }
其中参数的定义如下:
interval:检查的周期
fall:允许的检查失败次数,若失败次数超过该值,则后端被标记为"down"。
rise:检查的成功次数达到该值,则后端被标记为“up”。
timeout:检查的超时时间。
type:后端检查的协议类型。
5:在某一个请求路径下运用代理:
location / { root html; index index.html index.htm; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_pass http://xxxxxx; }
6:开启后端存活状态页面,便于查看后端状态。
location /status { check_status; access_log off; }
可以看到我现在的upstream服务组中,有一个后端是'up'状态,有一个后端是'down'不可用状态。
利用nginx_upstream_check模块检查nginx代理后端存活
原文地址:http://blog.51cto.com/icenycmh/2091910