首页 > 技术文章 > centos7.5安裝nginx并添加健康檢查模塊

shiqing-zhang 2020-06-02 11:09 原文

安裝nginx

  • 安裝依賴

  yum install gcc gcc-c++ pcre-devel zlib-devel -y(配置本地源安裝就行)

  • 下載軟件

  我用的是nginx-1.10.2

  • 解壓、編譯安裝

  tar -xvzf nginx-1.10.2.tar.gz

  cd nginx-1.10.2

  ./configure --prefix=/application/nginx

  make && make install

 

安裝第三方監控檢測模塊

  • 下載模塊 nginx_upstream_check_module-master.zip 
  • 解壓(unzip、路徑為/application/nginx_upstream_check_module-master)
  • 進入nginx1.10.2的源碼包目錄(我源碼目錄刪了,重新上傳了一份)

  cd /soft/nginx-1.10.2

  • 對nginx打後臺健康檢查的補丁,需要把打補丁的命令安裝完畢

  rpm -qa | grep patch  如果沒有安裝patch,就yum install -y patch

  • 打upstream_check補丁到nginx-1.10.2內

  patch -p0</application/nginx_upstream_check_module-master/check_1.11.1+.patch

 

  •  打完補丁后進行編譯

  因為需要添加  --add-module=/application/nginx_upstream_check_module-master

  如果其他编译参数和之前保持一致,但又不记得之前的编译参数,可使用 nginx -V 命令查看

 

  ./configure --user=nginx --group=nginx --prefix=/application/nginx-1.10.2/ --with-http_stub_status_module --with-http_ssl_module --add-module=/application/nginx_upstream_check_module-master

  make && make install

  make clean

  • 修改配置文件  vim /application/nginx/conf/nginx.conf

upstream tomcat{
server tomcat_ip:port;
server tomcat_ip:port;
check interval=5000 rise=2 fall=3 timeout=5000 type=http;
# HEAD / HTTP/1.1\r\nConnection: keep-alive\r\n\r\n;
check_http_send "HEAD / HTTP/1.0\r\n\r\n Connection: keep-alive\r\n\r\n";
# check_http_expect_alive http_2xx http_3xx;
}

location /nginx_status{
stub_status on;
# access_log /usr/local/nginx/logs/status.log;
# auth_basic "nginxstatus";
}

location /tomcat_status{
check_status;
access_log off;
#allow IP;
#deny all;
}

重新啟動nginx  ../sbin/nginx -s reload

訪問網頁:http://nginx的IP:port/tomcat_status

健康監測模塊下的一些參數說明:

- interval:向后端发送的健康检查包的间隔ms。

- fall(fall_count): 如果连续失败次数达到fall_count,服务器就被认为是down。

- rise(rise_count): 如果连续成功次数达到rise_count,服务器就被认为是up。

- timeout: 后端健康请求的超时时间。

- default_down: 设定初始时服务器的状态,如果是true,就说明默认是down的,如果是false,就是up的。

默认值是true,也就是一开始服务器认为是不可用,要等健康检查包达到一定成功次数以后才会被认为是健康的。

- type:健康检查包的类型,现在支持以下多种类型

  - tcp:简单的tcp连接,如果连接成功,就说明后端正常。

  - ssl_hello:发送一个初始的SSL hello包并接受服务器的SSL hello包。

  - http:发送HTTP请求,通过后端的回复包的状态来判断后端是否存活。

  - mysql: 向mysql服务器连接,通过接收服务器的greeting包来判断后端是否存活。

  - ajp:向后端发送AJP协议的Cping包,通过接收Cpong包来判断后端是否存活。

- port: 指定后端服务器的检查端口。你可以指定不同于真实服务的后端服务器的端口,比如后端提供的是443端口的应用,你可以去检查80端口的状态来判断后端健康状况。默认是0,表示跟后端server提供真实服务的端口一样。

  如果 type 为 http ,你还可以使用check_http_send来配置http监控检查包发送的请求内容,为了减少传输数据量,推荐采用 HEAD 方法。当采用长连接进行健康检查时,需在该指令中添加keep-alive请求头,如: HEAD / HTTP/1.1\r\nConnection: keep-alive\r\n\r\n 。当采用 GET 方法的情况下,请求uri的size不宜过大,确保可以在1个interval内传输完成,否则会被健康检查模块视为后端服务器或网络异常。

  stub_status on;

  Active connections: 对后端发起的活动连接数.
  Server accepts handled requests: Nginx总共处理了38810620个连接,成功创建38810620次握手(证明中间没有失败的),总共处理了298655730个请求.
  Reading: Nginx 读取到客户端的Header信息数.
  Writing: Nginx 返回给客户端的Header信息数.
  Waiting: 开启keep-alive的情况下,这个值等于 active – (reading + writing),意思就是Nginx已经处理完成,正在等候下一次请求指令的驻留连接.
  所以,在访问效率高,请求很快被处理完毕的情况下,Waiting数比较多是正常的.如果reading +writing数较多,则说明并发访问量非常大,正在处理过程中.

 

 nginx添加其他模塊

  执行./nginx -V,把configure arguments:的值记录下来

  找到当初安装nginx时的源码,cd到源码目录下(或者下载一个源码并解压) 

  ./configure [参数值]

  上面的[参数值]就是刚才configure arguments的值,再加上我们所需要的模块 

  然后make一下,注意 不要 make install,不然就覆盖安装现有nginx了
  make完之后在objs目录下就可以看到新编译的nginx文件了
  我们cd到objs目录测试一下新编译的nginx

  ./nginx -t

  把新nginx cp过去替换(先做備份)

 

 

注:本文主要用於個人學習與總結,如有錯誤期待各位大佬的指導!

推荐阅读