Apache服务器性能监控

时间:2023-11-22 17:42:02

Apache服务器性能监控

1、使用自带mod_status模块监控

1)加载mod_status.so 模块

在httpd.conf中打开LoadModule status_module modules/mod_status.so

2)修改httpd.conf配置文件增加(删注释#)如下内容:

<Location /server-status>
    SetHandler server-status
    Order deny,allow
    Deny from all
    Allow from all
</Location>
ExtendedStatus On

<location /server-status>:server-status这个名字可以修改。
Deny from:表示禁止的访问地址;nothing 表示没有禁止访问的地址 。
Allow from:表示允许的地址访问;all 表示所有的地址都可以访问。
ExtendedStatus On:显示其他信息,包括子httpd进程的应答信息。
Order deny,allow:优先级顺序,deny---拒绝,allow--允许。

重启apache服务器后在浏览器中访问:http://serverip/server-status 或 http://serverip/server-status?refresh=N(刷新时间) 或 http://serverip/server-status/auto(简单的状态表格)
   Apache服务器性能监控

重要指标:  

  • Total Accesses:到目前为止apache接收的联机数量
  • Total kBytes:接收的总的字节数
  • Uptime:服务器运行的总时间(单位:s)
  • CPULoad:当前由apache服务器消耗的CPU
  • ReqPerSec:平均每秒请求数,也就是命中率HPS
  • BytesPerSec:平均每秒发送的字节数
  • BytesPerReq:平均每个请求发送的字节数
  • BusyWorkers:提供服务的线程数,正在工作数
  • IdleWorkers:空闲的线程数

2、使用自带mod_info模块监控

 相对于mod_status模块提供的服务器状态信息,mod_info主要提供服务器的配置信息,并且不能动态更新

修改httpd.conf配置文件增加(删注释#)如下内容:

<Location /server-info>
  SetHandler server-info
  Order deny,allow
  Deny from all
  Allow from all
</Location>

重启apache服务器后在浏览器中访问:http://serverip/server-info,可以使用如下查询参数:

?config  显示apache配置文件

?<module-name>  显示模块相关信息

?list   显示所有使用中的模块列表

?server   显示基本的服务器信息

?hooks   显示每个模块所属的钩子列表

另外,mod_info模块还提供了AddModuleInfo指令来为server-info显示的模块增加额外的定制信息。

apache自带的mod_status和mod_info模块提供的监控功能比较弱,而且还可能会带来有安全方面的问题,所以一般建议取消这些模块功能,使用第三方工具来进行监控。

3、第三方工具监控

zabbix:基于PHP脚本的分布式系统监控以及网络监视功能的企业级解决方案,也能监控apache服务器。

Nagios:监视系统运行状态和网络信息的监视系统,和zabbix一样也提供基于Web的管理页面

4、LR监控apache服务器

      开启mod_status模块功能,在LR的controller中找到apache资源图双击并右键添加度量,如下图:

Apache服务器性能监控

     添加apache服务器IP地址、选择系统平台、添加需要监控的计数器即可进行监控了。

     Apache服务器性能监控                         Apache服务器性能监控

可能或存在Apache版本提供的计数器与LR默认计数器不一致的问题,就需要通过修改LR安装目录下\dat\monitors下的apache.cfg配置文件来解决。

5、利用apachetop工具监控apache日志

apachetop以类似top命令的方式实时显示apache的访问日志的统计信息,安装apachetop工具后,运行如下命令即可:

apachetop -f /usr/local/apache2/logs/access_log (apache日志文件目录)

6、其他实用监控命令

1)用ps来看httpd进程数

ps aux | grep httpd | wc -l

2)用netstat来看当前的连接数

netstat -ant | grep ":80" | wc -l

3) 实时检测httpd连接数

watch -n 1 -d  "pgrep httpd | wc -l"

4)计算httpd进程占用内存的平均数

ps aux|grep -v grep|awk ‘/httpd/{sum+=$6}; END{print sum/n}’

5)查看Apache的并发请求数及期TCP连接状态

netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'

返回结果示例:
LAST_ACK 5
SYN_RECV 30
ESTABLISHED 1597
FIN_WAIT1 51
FIN_WAIT2 504
TIME_WAIT 1057

• 其中的SYN_RECV表示正在等待处理的请求数;ESTABLISHED表示正常数据传输状态;TIME_WAIT表示处理完毕,等待超时结束的请求数.

   状态:描述
• CLOSED:无连接是活动的
• LISTEN:服务器在等待进入呼叫
• SYN_RECV:一个连接请求已经到达,等待确认
• SYN_SENT:应用已经开始,打开一个连接
• ESTABLISHED:正常数据传输状态
• FIN_WAIT1:应用说它已经完成
• FIN_WAIT2:另一边已同意释放
• ITMED_WAIT:等待所有分组死掉
• CLOSING:两边同时尝试关闭
• TIME_WAIT:另一边已初始化一个释放
• LAST_ACK:等待所有分组死掉