7点微信公众号:请点这里。7点测试网QQ总群:277957570。

7点测试网

 找回密码
 注册7点

QQ登录

只需一步,快速开始

查看: 1402|回复: 2
打印 上一主题 下一主题

Apache性能监控

[复制链接]
跳转到指定楼层
1#
发表于 2012-12-19 21:41:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

我们平时使用apache常常了解他的性能只能使用ps aux|grep httpd|wc -l查看有多少个进程,但处理了多少http的请求我们不清楚,进程是不是在工作,还是在等都不是很明白,要了解apache的性能,我们需要使用Apache Server Status的模块来详细了解apache工作的怎么样.并可以使用cacti来监控它.

对Apache Server Status的启用
对Apache的状态管理的模块是LoadModule status_module modules/mod_status.so,所以这个需要有,然后打开下面的配置
ExtendedStatus On
配置Apache Server Status的权限
<location /server-status>
         SetHandler server-status
         Order Deny,Allow
         Deny from all
         Allow from .foo.com
</location>
打开查看的话就使用http:// your.server.name/server-status来访问,注意VH的apache要设置在一个VH中,不然你分不清是那个地址来查看看这个信息.但ExtendedStatus不能放在VH中.

调用接口
http:// your.server.name/server-status,将会生产详细的状态报表,可以在浏览器中直接浏览。
另外可以加下面两种参数:
?refresh=N :设置多久自动刷新一次
?auto :生产机器可以读状态

server-status 的输出中每个字段所代表的意义如下:
字段                         说明
Server Version       Apache 服务器的版本。
Server Built         Apache 服务器编译安装的时间。
Current Time        目前的系统时间。
Restart Time         Apache 重新启动的时间。
Parent Server Generation        Apache 父程序 (parent process) 的世代编号,就是 httpd 接收到 SIGHUP 而重新启动的次数。
Server uptime         Apache 启动后到现在经过的时间。
Total accesses         到目前为此 Apache 接收的联机数量及传输的数据量。
CPU Usage           目前 CPU 的使用情形。
_SWSS....            所有 Apache process 目前的状态。每一个字符表示一个程序,最多可以显示 256 个程序的状态。
Scoreboard Key         上述状态的说明。以下为每一个字符符号所表示的意义:
    * _:等待连结中。
    * S:启动中。
    * R:正在读取要求。
    * W:正在送出回应。
    * K:处于保持联机的状态。
    * D:正在查找DNS。
    * C:正在关闭连结。
    * L:正在写入记录文件。
    * G:进入正常结束程序中。
    * I:处理闲置。
    * .:尚无此程序。
Srv        本程序与其父程序的世代编号。
PID        本程序的process id。
Acc        分别表示本次联机、本程序所处理的存取次数。
M         该程序目前的状态。
CPU        该程序所耗用的CPU资源。
SS         距离上次处理要求的时间。
Req        最后一次处理要求所耗费的时间,以千分之一秒为单位。
Conn       本次联机所传送的数据量。
Child       由该子程序所传送的数据量。
Slot        由该 Slot 所传送的数据量。
Client       客户端的地址。
VHost       属于哪一个虚拟主机或本主机的IP。
Request     联机所提出的要求信息。

报表相当不错吧。

Linux下查看脚本
在linux下编写一个state脚本,可以方便查看apache状态。
#!/bin/sh
wget -o /dev/stdout -O /dev/stdout "http://localhost/server-status?auto"

运行state脚本可以得到如下结果:
--08:37:58--  http://localhost/server-status?auto
           => `/dev/stdout'
正在解析主机 localhost... 127.0.0.1
Connecting to localhost|127.0.0.1|:80... 已连接。
已发出 HTTP 请求,正在等待回应... 200 OK
长度:433 [text/plain]
Total Accesses: 38405
Total kBytes: 311445
CPULoad: 3.29514
Uptime: 2243
ReqPerSec: 17.1222
BytesPerSec: 142184
BytesPerReq: 8304.12
BusyWorkers: 6
IdleWorkers: 20
Scoreboard: C__________K___W___KW__K_........_..............................................................................................................................................................................................................................

    0K                                                       100%   45.88 MB/s

08:37:58 (45.88 MB/s) - `/dev/stdout' saved [433/433]

各结果项介绍如上。

在Cacti中进行监控
下载模板和脚本
http://forums.cacti.net/about25227.html&highlight=apachestats
在上面的地址下载一个叫 ApacheStats08.zip的,中间有二个文件,一个处理脚本php的,另一个是xml的文件.
1.其中的ss_apache_stats.php是脚本文件,它是一个php的文件,放到你的cacti/scripts/下面.
2.接下来在cacti界面导入cacti_host_template_webserver_-_apache.xml这个文件
3.你就可以在cacti中加入这些设置.就不细写了,如下
被监测的apache服务器需要向上面一样,打开mod_status功能,记的设置好权限访问,不然任何人都可以见到可不好哦
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享
2#
发表于 2012-12-28 16:48:24 | 只看该作者
顶一下,现在看还看不懂,希望以后看到的时候能看懂
3#
发表于 2013-2-5 15:54:15 | 只看该作者
谢谢LZ,我们用的小红帽,出来的状态值偏少
您需要登录后才可以回帖 登录 | 注册7点

本版积分规则

QQ|小黑屋|手机版|Archiver|7点测试网 ( 京ICP备09084002号

GMT+8, 2018-2-21 11:35 , Processed in 0.192437 second(s), 24 queries .

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表