微服务系列文章 之 Nginx服务状态监控的方法

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

1. 模块安装

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

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

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

|---|----------------------------------------------|
| | ./configure --with-http_stub_status_module |

2. Nginx配置

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

|---|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| | location /hxbcdnstatus { ``stub_status on; ``access_log off; ``  allow 127.0.0.1; ``deny all; ``#auth_basic "NginxStatus"; ``#auth_basic_user_file conf/nginxstaus; } |

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

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

3. 状态查看

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

|---|-----------------------------------------------------------------------------------------------------------------------|
| | Active connections: 100 server accepts handled requests ``1075 1064 6253 Reading: 0 Writing: 5 Waiting: 95 |

4. 参数说明

active connections -- 活跃的连接数量

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

每个连接有三种状态waitingreadingwriting

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, Sa}'

相关推荐
野生技术架构师13 分钟前
从 B+ 树到应用层分表:MySQL 海量数据架构解析
数据库·mysql·架构
Maimai1080824 分钟前
Web3 前端交易系统如何落地:从下单 UI 到 Operation 编码、签名与实时状态更新
前端·react.js·ui·架构·前端框架·web3
heimeiyingwang33 分钟前
【架构实战】灰度发布实战:安全上线不翻车
安全·架构
ttwuai36 分钟前
XYGo Admin 后端分层架构:Controller→Service→Logic→DAO 实战解析
架构·goframe·后台框架
myenjoy_140 分钟前
大规模采集架构——从单台网关到千点集群
架构·wpf
qq_411262421 小时前
AI-02模组架构与Coze智能体接入说明
人工智能·ai·架构·esp32-c3·coze·四博
HavenlonLabs1 小时前
三年内,AI 控制会走向安全的一线
人工智能·安全·金融·架构·安全架构
故渊at1 小时前
第十三板块:Android 综合架构与未来演进 | 第三十一篇:Android 架构演进与 Fuchsia OS 的挑战
android·架构·宏内核·微内核·fuchsia·ipc 性能博弈
咚为2 小时前
Claude Code 深度定制指南:从分层架构到 AI 参谋系统的高级搭建实践
人工智能·架构
X54先生(人文科技)2 小时前
X54先生与“启”关于涌现对话
人工智能·架构·开源·零知识证明