一、模块healthcheck_nginx_upstreams
http://wiki.nginx.org/HttpHealthcheckModule
1、下载安装,
在https://github.com/liseen/healthcheck_nginx_upstreams下载该模块,没有公布的版本,下载时要双击打开后,将代码另存的方式下载,
也可以去这里下载: http://download.csdn.net/detail/ly_stu/5976009
2、进入nginx的源码目录 为nginx打补丁 healthcheck.pathch #注意路径
#patch –p1< ../cep21-healthcheck_nginx_upstreams/healthcheck.patch
编译安装nginx
./configure --user=www --group=www--prefix=/usr/local/nginx/ --with- pcre=/usr/local/src/pcre-8.31--with-http_stub_status_module --with-http_ssl_module --add-module=../cep21-healthcheck_nginx_upstreams-b33a846/ && make && make install&& make clean
3、配置nginx.conf healthcheck_nginx_upstreams的context为upstream
分别在两个站点目录下创建error.jsp探测页面,注意防火墙的阻挡,touch error.jsp
http{
……
upstream backend {
server 192.168.15.65:80;
server 192.168.15.183:8080;
#开启
healthcheck_enabled;
#检测每一端的延迟,单位为毫秒
healthcheck_delay 1000;
#超过2000毫秒为超时
healthcheck_timeout 2000;
#失败尝试
healthcheck_failcount 3;
#实际检测
healthcheck_send "GET /error.jspHTTP/1.0";
}
server{
……
location ~ /health {
healthcheck_status;
access_log off;
allow 192.168.15.65/20;
deny all;
}
……
}
}
网页查看运行结果:
注意:HttpHealthcheckModule与nginx_upstream_check_module安装时补丁包有一定冲突,不可同时安装。
二、模块nginx_upstream_check_module
获取该模块版本包
https://github.com/yaoweibin/nginx_upstream_check_module/releases
进入nginx的解压目录:
#patch -p1 < /path/to/nginx_http_upstream_check_module/check.patch
注:因nginx版本更新,1.2以上版本的nginx,补丁为check_1.2.1+.patch
编译安装nginx
#./configure --prefix=/usr/local/nginx/ \
--with-pcre=/usr/local/src/pcre-8.31\
--with-http_stub_status_module \
--with-http_ssl_module \
--add-module=/path/to/nginx_http_upstream_check_module
#make && makeinstall && make clean
在nginx.conf配置文件里面的upstream加入健康检查,如下:
http{
……
upstreamwww.example.com {
server 192.168.15.187:80;
server 192.168.15.188:80;
#追加下面行就ok了
check interval=1500 rise=2 fall=2 timeout=1000;
}
server{
……
location ~ /nstatus {
check_status;
access_log off;
allow 192.168.1.176;
}
}
}
注:无关配置项省略。
判断语法,重载nginx服务
[root@master ~]# /usr/local/nginx/sbin/nginx -t
[root@master ~]# /usr/local/nginx/sbin/nginx -s reload
网页查看运行结果:
虽然上面两个模块都可以实现对后端的检测,但总是有一种鸡肋的感觉,对于有多个应用前端的生产环境而言,每个前端都需要安装该模块插件,当然也是单独的页面显示,会给用户返回大量的信息【包括很多正常的信息,其实检测后端的目的就是了解到错误连接,并实现告警】,并不理想,而且不能实现告警。继续学习寻找中[手动写脚本]……