Nginx服务状态监控

悠悠 2022-06-06 23:28 263阅读 0赞

Nginx服务状态监控

  在Nginx的插件模块中有一个模块stub_status可以监控Nginx的一些状态信息,默认安装可能没有这个模块,手动编译的时候加一下即可。

  1. 模块安装

  先使用命令查看是否已经安装这个模块:

  1. [root@ihxb123Z nginx]# ./nginx -V (V大写会显示版本号和模块等信息、v小写仅显示版本信息。

  如果已经安装,会在显示的信息中包含 —with-http_stub_status_module信息。如果没有此模块,需要重新安装,编译命令如下:

  1. ./configure with-http_stub_status_module

  2. Nginx配置

  安装后只要修改nginx配置即可,配置如下:

复制代码

  1. location /hxbcdnstatus {
  2. stub_status on;
  3. access_log off;
  4.   allow 127.0.0.1;
  5. deny all;
  6. #auth_basic "NginxStatus";
  7. #auth_basic_user_file conf/nginxstaus;
  8. }

复制代码

  此处默认只有本地访问,如果远程可以查看需要加相关的IP或者干脆去掉Deny all即可。加密文件可以使用#htpasswd -c /usr/nginx/conf hxb 命令来创建。配置完成后需要重启Nginx服务。

  状态配置只能是针对某个Nginx服务。目前Nginx还无法做到针对单个站点进行监控。

  3. 状态查看

  配置完成后在浏览器中输入http://127.0.0.1/hxbcdnstatus查看,显示信息如下:

  1. Active connections: 100
  2. server accepts handled requests
  3. 1075 1064 6253
  4. Reading: 0 Writing: 5 Waiting: 95

  4. 参数说明

  active connections – 活跃的连接数量

  server accepts handled requests — 总共处理了107520387个连接 , 成功创建107497834次握手, 总共处理了639121056个请求

  每个连接有三种状态waiting、reading、writing

  reading —读取客户端的Header信息数.这个操作只是读取头部信息,读取完后马上进入writing状态,因此时间很短。

  writing — 响应数据到客户端的Header信息数.这个操作不仅读取头部,还要等待服务响应,因此时间比较长。

  waiting — 开启keep-alive后等候下一次请求指令的驻留连接.

  正常情况下waiting数量是比较多的,并不能说明性能差。反而如果reading+writing数量比较多说明服务并发有问题。

  补充:

  查看Nginx并发进程数:ps -ef | grep nginx | wc -l

  查看Web服务器TCP连接状态:netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}‘

发表评论

表情:
评论列表 (有 0 条评论,263人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Nginx服务状态监控

    [Nginx服务状态监控][Nginx]   在Nginx的插件模块中有一个模块stub\_status可以监控Nginx的一些状态信息,默认安装可能没有这个模块,手动编

    相关 zabbix 监控nginx状态

    很久没有写博客了,今天遇到个麻烦事,网站的访问量突然加大,监控报警是把我的机房带宽全部跑满了,最后把硬件防火墙的策略改动之后才恢复正常。然后负责人要关于nginx网站,和带宽的

    相关 zabbix 监控nginx状态

    很久没有写博客了,今天遇到个麻烦事,网站的访问量突然加大,监控报警是把我的机房带宽全部跑满了,最后把硬件防火墙的策略改动之后才恢复正常。然后负责人要关于nginx网站,和带宽的