涨薪技术|0到1学会性能测试第43课-apache status模块监控

涨薪技术|0到1学会性能测试第43课-apache status模块监控

精选文章moguli202025-01-16 10:39:2417A+A-

前面的推文我们认识了apache目录结构与配置知识,今天我们继续来看下apache监控技术,究竟是怎么做性能监控的。后续文章都会系统分享干货,带大家从0到1学会性能测试,另外还有教程等同步资料,文末加小编VX(flyhappy111)领取即可。

Apache监控技术

关于apache监控通常会有两种方法:

一是:使用apache自带的status监控模块进行监控;

二是:使用apachetop工具进行监控;

本章节详细的介绍第一种监控方法。


01status模块监控

status模块是为服务器管理来获取服务器性能的相关信息,这些信息将以一个HTML页面的方式来显示,该页面以比较简单的阅读方式来显示当前服务器的统计信息,并且还可以自动刷新的方式来实时显示这些统计信息。

使用status模块监控apache服务器的步骤如下:

1.开启status模块

Apache服务器中的httpd配置文件中有很多可被调用的模块,主要包括以下模块:

# LoadModule foo_module modules/mod_foo.so
LoadModule access_module modules/mod_access.so
LoadModule actions_module modules/mod_actions.so
LoadModule alias_module modules/mod_alias.so
LoadModule asis_module modules/mod_asis.so
LoadModule auth_module modules/mod_auth.so
#LoadModule auth_anon_module modules/mod_auth_anon.so
#LoadModule auth_dbm_module modules/mod_auth_dbm.so
#LoadModule auth_digest_module modules/mod_auth_digest.so
LoadModule autoindex_module modules/mod_autoindex.so
#LoadModule cern_meta_module modules/mod_cern_meta.so
LoadModule cgi_module modules/mod_cgi.so
#LoadModule dav_module modules/mod_dav.so
#LoadModule dav_fs_module modules/mod_dav_fs.so
LoadModule dir_module modules/mod_dir.so
LoadModule env_module modules/mod_env.so
#LoadModule expires_module modules/mod_expires.so
#LoadModule file_cache_module modules/mod_file_cache.so
#LoadModule headers_module modules/mod_headers.so
LoadModule imap_module modules/mod_imap.so
LoadModule include_module modules/mod_include.so
#LoadModule info_module modules/mod_info.so
LoadModule isapi_module modules/mod_isapi.so
LoadModule log_config_module modules/mod_log_config.so
LoadModule mime_module modules/mod_mime.so
#LoadModule mime_magic_module modules/mod_mime_magic.so
#LoadModule proxy_module modules/mod_proxy.so
#LoadModule proxy_connect_module modules/mod_proxy_connect.so
#LoadModule proxy_http_module modules/mod_proxy_http.so
#LoadModule proxy_ftp_module modules/mod_proxy_ftp.so
LoadModule negotiation_module modules/mod_negotiation.so
#LoadModule rewrite_module modules/mod_rewrite.so
LoadModule setenvif_module modules/mod_setenvif.so
#LoadModule speling_module modules/mod_speling.so
LoadModule status_module modules/mod_status.so
#LoadModule unique_id_module modules/mod_unique_id.so
LoadModule userdir_module modules/mod_userdir.so
#LoadModule usertrack_module modules/mod_usertrack.so
#LoadModule vhost_alias_module modules/mod_vhost_alias.so
LoadModule ssl_module modules/mod_ssl.so

前面有“#”号的代码,表示该代码被注释不生效,如果需要该行代码生效,那么需要将前面的“#”号取消。监控Apache的状态需要启动LoadModule status_module modules/mod_status.so模块。

2.设置扩展日志信息

设置扩展日志信息的命令如下:

语法:
ExtendedStatus On|Off
默认值:
ExtendedStatus Off
这个功能仅在apache 1.3.2或更高版本才可以使用。
在httpd.conf配置文件中添加这行代码即可。

默认情况下,只能看到以下一些基本信息,如图10-1所示

如果需要显示所有的状态信息,需要将ExtendedStatus的值设置为On,该选项的缺省值为Off,所以正常情况下只能看到如图10-1所示的基本信息,在监控过程中需要将该选项的值设置为On,以便显示Apache服务器所有的状态信息。

3.设置SeeRequestTail

该指令是使用设置显示请求的前63个字符还是显示最后63个字符。

语法:
SeeRequestTail On|Off
默认值:
SeeRequestTail Off
这个功能仅在apache 2.2.7或更高版本才可以使用。
在httpd.conf配置文件中添加这行代码即可。

4.设置访问status权限

服务器的状态信息是通常“server-status”中的“handler”调用,server-status的代码如下:

<Location /server-status>
    SetHandler server-status
    Order deny,allow
    Deny from all
    Allow from all
</Location>
Deny from:表示禁止的访问地址;
Allow from:表示允许的地址访问;

注意:在监控之前一定要启动“server-status”模块,否则SetHandler无法读到服务器的状态信息,进而导致监控失败。

5.启用监控

现在可以通过使用Web浏览器访问页面来访问服务器统计信息,http://your.server.name/server-status。

测试是否可以正确的显示Apache服务器的状态信息,如果正确,则会显示如图10-2所示的详细信息。

6.状态信息自动更新

关于显示详细状态还有两个参数:

?refresh=N:设置每N秒后动态刷新一次详细信息(?refresh=5表示每5秒钟刷新一次),如果不设置具体的时间间隔(如?refresh),那么缺省值为每1秒钟动态刷新一次详细信息。

?auto:表示服务器处于访问状态下的动态态信息;

其语法格式为http://your.server.name/server-status?refresh=N

如http://localhost/server-status?auto&refresh=5表示每5秒动态刷新一次详细信息,结果如图10-3所示

Total Accesses:到目前为此Apache接收的联机数量及传输的数据量;

To kBytes:接收的总的字节数;

Uptime:服务器运行的总时间(单位秒);

ReqPerSec:平均每秒请求数;

BytesPerSec:平均每秒发送的字节数;

BytesPerReq:平均每个请求发送的字节数;

BusyWorkers:正在工作数;

IdleWorkers:空闲工作数;

BusyWorkers加IdleWorkers的和为服务所允许的同时工作的线程数,配置文件中同时允许的最多线程中的设置项为ThreadsPerChild,其缺少值为250。即ThreadsPerChild=BusyWorkers+IdleWorkers。

只输入http://IP/server-status,则只显示相关的统计信息,而非动态信息,信息内容如下:

表示当前所有线程在处理请求时所处于的状态。线程处理主要的状态包括以下几种:

"_":表示等待连接

"S":表示连接开始,可以发送请求

"R":表示读请求的状态

"W":表示服务器正响应回复数据的状态

"K":表示保持长连接状态

"D":表示域名解析状态

"C":表示连接正在关闭

"L":表示正在退出

"G":表示退出完成

"I":表示空闲的线程

".":表示当前线程没的打开slot

统计部分内容信息含义依次为:到目前为止Apache接收的联机数量及传输的数据量、已发送的总的字节数、平均每秒请求数、平均每秒发送的字节数、平均每个请求发送的字节数、当前正在请求的线程数、空闲的结程数。

关于M列的状态主要包括以下几种:

_:等待连结中。

S:启动中。

R:正在读取要求。

W:正在送出回应。

K:处于保持联机的状态。

D:正在查找DNS。

C:正在关闭连结。

L:正在写入记录文件。

G:进入正常结束程序中。

I:处理闲置。

.:尚无此程序。

关于请求表格中各列的含义见表10-1

各选项的含义:

Srv:表示子进程

PID:子进程的进程号

Acc:表示连接数量、子进程、slot

M:表示当前请求所处的状态

CPU:表示CPU使用情况

SS:表示当前一共有多少请求

Req:表示一共发的请求数

Conn:表示当前连接传输的字节数

Child:表示每个进程传输的字节数

Slot:表示当前slot一共传输了多少字节数

点击这里复制本文地址 以上内容由莫古技术网整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!
qrcode

莫古技术网 © All Rights Reserved.  滇ICP备2024046894号-2