zoukankan      html  css  js  c++  java
  • centos7.5安裝nginx并添加健康檢查模塊

    安裝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 Connection: keep-alive ;
    check_http_send "HEAD / HTTP/1.0 Connection: keep-alive ";
    # 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 Connection: keep-alive 。当采用 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过去替换(先做備份)

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

  • 相关阅读:
    get_folder_size.ps1
    python3-database-shelve
    Windows中实现不依赖账户登录的开机启动程序
    SpringBoot+SpringDataJPA如何实现自定义且自由度高的查询[多表,多查询条件,多排序条件,分页,自定义sql封装]
    Windows phone 8.1之数据绑定(Data Binding)
    TextBox使用技巧--转载
    在Eclipse中使用git把项目导入到git中--转载
    运用多种知识点实现一个综合小游戏
    Git帮助之初始化项目设置向导
    如何从Eclipse导入github上的项目源码--转载
  • 原文地址:https://www.cnblogs.com/shiqing-zhang/p/13029492.html
Copyright © 2011-2022 走看看