背景
公司某团队提供的服务接口太糟糕,作为上游服务,该团队的服务打包提供了一批的ip和端口,如下:
192.168.1.1:80
192.168.1.2:80
192.168.1.3:80
192.168.1.4:80
作为下游业务方,调用上游服务自然不能选择只连接其中一个节点,于是自然想到了nginx的upstream ,将地址全部配置到upstream中就可以实现按需的负载均衡。
但是社区版的nginx健康检查是被动健康检查,在真实场景中,上游服务已经故障了,upstream仍会调度请求到异常节点上去。看了下主动健康检查的方案,有nginx企业版,还有淘宝的第三方补丁,最后是直接一步到位Tengine。综合评估Tengine是最简单的方案,下面是流程:
一、安装
Tengine官网:https://tengine.taobao.org
http_upstream_check模块的介绍:https://tengine.taobao.org/document/http_upstream_check.html
按照官方文档提示的部署执行三板斧编译tengine
$ ./configure
$ make
# make install
实际按demo配置好之后,nginx一直提示unkown directive check。官网的说法是在Tengine 1.4.0之前没有默认开启,按道理我得环境是2.4.1已经开启了,但是实际上并未开启。查阅博客发现一篇文章:https://codeleading.com/article/34553896067/
原来要启用相关模块还是要在configure 指令中显示引用的
./configure --add-module=./modules/ngx_http_upstream_check_module
#modules目录下还有其他模块,如果要启用的话,使用相同办法在configure这添加
make 、make install 之后默认安装路径在 /usr/local/nginx , 按照官网demo配置后,确认可以正常主动健康监测。且在我的测试环境,基本可以实现快速识别异常节点。