微服务系列文章 之 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个请求 每个连接有三种状态`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\]}'

相关推荐
roman_日积跬步-终至千里12 小时前
【Docker多节点部署】基于“配置即身份“理念的 Docker 多节点 StarRocks 高可用集群自动化部署方案
java·docker·微服务
serendipity_hky17 小时前
【微服务 - easy视频 | day03】服务与服务之间的调用
spring boot·spring cloud·微服务·架构
三口吃掉你18 小时前
微服务之Nacos(注册中心、配置中心)
微服务·nacos·架构
失散1320 小时前
分布式专题——51 ES 深度分页问题及其解决方案详解
java·分布式·elasticsearch·架构
Lethehong1 天前
百万迁移费成历史?金仓数据库“零代码”替换Oracle,我们扒了扒它的技术底牌
后端·mysql·架构
门思科技1 天前
LoRa 与 LoRaWAN 技术解析:物理层原理、网络架构与典型物联网应用场景
网络·物联网·架构
okjohn1 天前
《架构师修炼之路》——②对架构的基本认识
java·架构·系统架构·软件工程·团队开发
陈果然DeepVersion1 天前
Java大厂面试真题:从Spring Boot到AI微服务的三轮技术拷问(一)
java·spring boot·redis·微服务·kafka·面试题·oauth2
狼爷1 天前
如何防止重复提交订单?——从踩坑到优雅落地的实战指南
java·架构
卓豪终端管理1 天前
零信任架构落地难?从终端安全开始破局
安全·架构