Zabbix 监控apache server-status CentOS 6
首先打开apache的server-status (一般此功能是关闭的):
这里是yum 安装的,编译安装的在自定义目录中找到 httpd.conf
- vim /etc/httpd/conf/httpd.conf
- #<location /server-status>
- # SetHandler server-status
- # Order Allow,Deny
- # Allow from all
- #</location>
打开注释 启用此功能 , 同时注意 这信息我不想让任何人都可以看到 就不能使用 allow from all 下面是一个示例:
- <location /server-status>
- SetHandler server-status
- Order Allow,Deny
- Deny from all
- Allow from 127.0.0.1
- Allow from 192.168.11.110
- Allow from 192.168.11.111
- Allow from 192.168.11.112
- </location>
保存 修改,重启apache
service httpd restart
[root@localhost shell]# curl 127.0.0.1/server-status
<!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 3.2 Final//EN”>
<html><head>
<title>Apache Status</title>
</head><body>
<h1>Apache Server Status for 127.0.0.1</h1>
<dl><dt>Server Version: Apache/2.2.15 (Unix) DAV/2 PHP/5.4.45 SVN/1.6.11</dt>
<dt>Server Built: Jul 18 2016 15:21:39
</dt></dl><hr /><dl>
<dt>Current Time: Wednesday, 26-Apr-2017 10:57:21 CST</dt>
<dt>Restart Time: Tuesday, 25-Apr-2017 04:02:02 CST</dt>
<dt>Parent Server Generation: 3</dt>
<dt>Server uptime: 1 day 6 hours 55 minutes 19 seconds</dt>
<dt>1 requests currently being processed, 9 idle workers</dt>
</dl><pre>__._W__.____…………………………………………….
……………………………………………………….
</pre>
<p>Scoreboard Key:<br />
“<b><code>_</code></b>” Waiting for Connection,
“<b><code>S</code></b>” Starting up,
“<b><code>R</code></b>” Reading Request,<br />
“<b><code>W</code></b>” Sending Reply,
“<b><code>K</code></b>” Keepalive (read),
“<b><code>D</code></b>” DNS Lookup,<br />
“<b><code>C</code></b>” Closing connection,
“<b><code>L</code></b>” Logging,
“<b><code>G</code></b>” Gracefully finishing,<br />
“<b><code>I</code></b>” Idle cleanup of worker,
“<b><code>.</code></b>” Open slot with no current process</p>
<p />
PID Key: <br />
<pre>
15018 in state: _ , 17680 in state: _ , 3068 in state: _
10415 in state: W , 26388 in state: _ , 8383 in state: _
32732 in state: _ , 27381 in state: _ , 11944 in state: _
435 in state: _ ,
</pre>
<hr />To obtain a full report with current status information you need to use the <code>ExtendedStatus On</code> directive.
</body></html>
<!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 3.2 Final//EN”>
<html><head>
<title>Apache Status</title>
</head><body>
<h1>Apache Server Status for 127.0.0.1</h1>
<dl><dt>Server Version: Apache/2.2.15 (Unix) DAV/2 PHP/5.4.45 SVN/1.6.11</dt>
<dt>Server Built: Jul 18 2016 15:21:39
</dt></dl><hr /><dl>
<dt>Current Time: Wednesday, 26-Apr-2017 10:57:21 CST</dt>
<dt>Restart Time: Tuesday, 25-Apr-2017 04:02:02 CST</dt>
<dt>Parent Server Generation: 3</dt>
<dt>Server uptime: 1 day 6 hours 55 minutes 19 seconds</dt>
<dt>1 requests currently being processed, 9 idle workers</dt>
</dl><pre>__._W__.____…………………………………………….
……………………………………………………….
</pre>
<p>Scoreboard Key:<br />
“<b><code>_</code></b>” Waiting for Connection,
“<b><code>S</code></b>” Starting up,
“<b><code>R</code></b>” Reading Request,<br />
“<b><code>W</code></b>” Sending Reply,
“<b><code>K</code></b>” Keepalive (read),
“<b><code>D</code></b>” DNS Lookup,<br />
“<b><code>C</code></b>” Closing connection,
“<b><code>L</code></b>” Logging,
“<b><code>G</code></b>” Gracefully finishing,<br />
“<b><code>I</code></b>” Idle cleanup of worker,
“<b><code>.</code></b>” Open slot with no current process</p>
<p />
PID Key: <br />
<pre>
15018 in state: _ , 17680 in state: _ , 3068 in state: _
10415 in state: W , 26388 in state: _ , 8383 in state: _
32732 in state: _ , 27381 in state: _ , 11944 in state: _
435 in state: _ ,
</pre>
<hr />To obtain a full report with current status information you need to use the <code>ExtendedStatus On</code> directive.
</body></html>
To obtain a full report with current status information you need to use the <code>ExtendedStatus On directive.</code>
看到这样的提示表示 需要开启ExtendedStatus On
vim /etc/httpd/conf/httpd.conf
ExtendedStatus On
ExtendedStatus On
重启apache
curl 127.0.0.1/server-status
<!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 3.2 Final//EN”>
<html><head>
<title>Apache Status</title>
</head><body>
<h1>Apache Server Status for 127.0.0.1</h1><dl><dt>Server Version: Apache/2.2.15 (Unix) DAV/2 PHP/5.4.45 SVN/1.6.11</dt>
<dt>Server Built: Jul 18 2016 15:21:39
</dt></dl><hr /><dl>
<dt>Current Time: Wednesday, 26-Apr-2017 11:05:38 CST</dt>
<dt>Restart Time: Wednesday, 26-Apr-2017 11:05:27 CST</dt>
<dt>Parent Server Generation: 0</dt>
<dt>Server uptime: 10 seconds</dt>
<dt>Total accesses: 3 – Total Traffic: 40 kB</dt>
<dt>CPU Usage: u.43 s.05 cu0 cs0 – 4.8% CPU load</dt>
<dt>.3 requests/sec – 4096 B/second – 13.3 kB/request</dt>
<dt>2 requests currently being processed, 6 idle workers</dt>
</dl><pre>____W_R_………………………………………………..
……………………………………………………….
</pre>
<p>Scoreboard Key:<br />
“<b><code>_</code></b>” Waiting for Connection,
“<b><code>S</code></b>” Starting up,
“<b><code>R</code></b>” Reading Request,<br />
“<b><code>W</code></b>” Sending Reply,
“<b><code>K</code></b>” Keepalive (read),
“<b><code>D</code></b>” DNS Lookup,<br />
“<b><code>C</code></b>” Closing connection,
“<b><code>L</code></b>” Logging,
“<b><code>G</code></b>” Gracefully finishing,<br />
“<b><code>I</code></b>” Idle cleanup of worker,
“<b><code>.</code></b>” Open slot with no current process</p>
<p />
<table border=”0″><tr><th>Srv</th><th>PID</th><th>Acc</th><th>M</th><th>CPU
</th><th>SS</th><th>Req</th><th>Conn</th><th>Child</th><th>Slot</th><th>Client</th><th>VHost</th><th>Request</th></tr><tr><td><b>0-0</b></td><td>5963</td><td>0/1/1</td><td>_
</td><td>0.25</td><td>7</td><td>287</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>74.207.253.220</td><td nowrap>blog.megamotormadness.com</td><td nowrap>GET /wp-login.php HTTP/1.0</td></tr><tr><td><b>1-0</b></td><td>5964</td><td>0/1/1</td><td>_
</td><td>0.23</td><td>6</td><td>257</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>74.207.253.220</td><td nowrap>blog.megamotormadness.com</td><td nowrap>POST /wp-login.php HTTP/1.0</td></tr>
<tr><td><b>4-0</b></td><td>5967</td><td>0/0/0</td><td><b>W</b>
</td><td>0.00</td><td>0</td><td>1472680755</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>127.0.0.1</td><td nowrap>localhost.localdomain</td><td nowrap>GET /server-status HTTP/1.1</td></tr>
<tr><td><b>5-0</b></td><td>5968</td><td>0/1/1</td><td>_
</td><td>0.00</td><td>3</td><td>1379</td><td>0.0</td><td>0.03</td><td>0.03
</td><td>189.83.74.83</td><td nowrap>edm.choies.com</td><td nowrap>GET /blogger/wanted_1.jpg HTTP/1.1</td></tr>
<tr><td><b>6-0</b></td><td>5969</td><td>0/0/0</td><td><b>R</b>
</td><td>0.00</td><td>4</td><td>0</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>?</td><td nowrap>?</td><td nowrap>..reading.. </td></tr>
</table>
<hr /> <table>
<tr><th>Srv</th><td>Child Server number – generation</td></tr>
<tr><th>PID</th><td>OS process ID</td></tr>
<tr><th>Acc</th><td>Number of accesses this connection / this child / this slot</td></tr>
<tr><th>M</th><td>Mode of operation</td></tr>
<tr><th>CPU</th><td>CPU usage, number of seconds</td></tr>
<tr><th>SS</th><td>Seconds since beginning of most recent request</td></tr>
<tr><th>Req</th><td>Milliseconds required to process most recent request</td></tr>
<tr><th>Conn</th><td>Kilobytes transferred this connection</td></tr>
<tr><th>Child</th><td>Megabytes transferred this child</td></tr>
<tr><th>Slot</th><td>Total megabytes transferred this slot</td></tr>
</table>
</body></html>
<html><head>
<title>Apache Status</title>
</head><body>
<h1>Apache Server Status for 127.0.0.1</h1><dl><dt>Server Version: Apache/2.2.15 (Unix) DAV/2 PHP/5.4.45 SVN/1.6.11</dt>
<dt>Server Built: Jul 18 2016 15:21:39
</dt></dl><hr /><dl>
<dt>Current Time: Wednesday, 26-Apr-2017 11:05:38 CST</dt>
<dt>Restart Time: Wednesday, 26-Apr-2017 11:05:27 CST</dt>
<dt>Parent Server Generation: 0</dt>
<dt>Server uptime: 10 seconds</dt>
<dt>Total accesses: 3 – Total Traffic: 40 kB</dt>
<dt>CPU Usage: u.43 s.05 cu0 cs0 – 4.8% CPU load</dt>
<dt>.3 requests/sec – 4096 B/second – 13.3 kB/request</dt>
<dt>2 requests currently being processed, 6 idle workers</dt>
</dl><pre>____W_R_………………………………………………..
……………………………………………………….
</pre>
<p>Scoreboard Key:<br />
“<b><code>_</code></b>” Waiting for Connection,
“<b><code>S</code></b>” Starting up,
“<b><code>R</code></b>” Reading Request,<br />
“<b><code>W</code></b>” Sending Reply,
“<b><code>K</code></b>” Keepalive (read),
“<b><code>D</code></b>” DNS Lookup,<br />
“<b><code>C</code></b>” Closing connection,
“<b><code>L</code></b>” Logging,
“<b><code>G</code></b>” Gracefully finishing,<br />
“<b><code>I</code></b>” Idle cleanup of worker,
“<b><code>.</code></b>” Open slot with no current process</p>
<p />
<table border=”0″><tr><th>Srv</th><th>PID</th><th>Acc</th><th>M</th><th>CPU
</th><th>SS</th><th>Req</th><th>Conn</th><th>Child</th><th>Slot</th><th>Client</th><th>VHost</th><th>Request</th></tr><tr><td><b>0-0</b></td><td>5963</td><td>0/1/1</td><td>_
</td><td>0.25</td><td>7</td><td>287</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>74.207.253.220</td><td nowrap>blog.megamotormadness.com</td><td nowrap>GET /wp-login.php HTTP/1.0</td></tr><tr><td><b>1-0</b></td><td>5964</td><td>0/1/1</td><td>_
</td><td>0.23</td><td>6</td><td>257</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>74.207.253.220</td><td nowrap>blog.megamotormadness.com</td><td nowrap>POST /wp-login.php HTTP/1.0</td></tr>
<tr><td><b>4-0</b></td><td>5967</td><td>0/0/0</td><td><b>W</b>
</td><td>0.00</td><td>0</td><td>1472680755</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>127.0.0.1</td><td nowrap>localhost.localdomain</td><td nowrap>GET /server-status HTTP/1.1</td></tr>
<tr><td><b>5-0</b></td><td>5968</td><td>0/1/1</td><td>_
</td><td>0.00</td><td>3</td><td>1379</td><td>0.0</td><td>0.03</td><td>0.03
</td><td>189.83.74.83</td><td nowrap>edm.choies.com</td><td nowrap>GET /blogger/wanted_1.jpg HTTP/1.1</td></tr>
<tr><td><b>6-0</b></td><td>5969</td><td>0/0/0</td><td><b>R</b>
</td><td>0.00</td><td>4</td><td>0</td><td>0.0</td><td>0.00</td><td>0.00
</td><td>?</td><td nowrap>?</td><td nowrap>..reading.. </td></tr>
</table>
<hr /> <table>
<tr><th>Srv</th><td>Child Server number – generation</td></tr>
<tr><th>PID</th><td>OS process ID</td></tr>
<tr><th>Acc</th><td>Number of accesses this connection / this child / this slot</td></tr>
<tr><th>M</th><td>Mode of operation</td></tr>
<tr><th>CPU</th><td>CPU usage, number of seconds</td></tr>
<tr><th>SS</th><td>Seconds since beginning of most recent request</td></tr>
<tr><th>Req</th><td>Milliseconds required to process most recent request</td></tr>
<tr><th>Conn</th><td>Kilobytes transferred this connection</td></tr>
<tr><th>Child</th><td>Megabytes transferred this child</td></tr>
<tr><th>Slot</th><td>Total megabytes transferred this slot</td></tr>
</table>
</body></html>
看到这样的信息表示成功
然后 添加 Zabbix 的监控和执行脚本
- vim /etc/zabbix/shell/apache_status.sh
- #!/bin/bash
- if [[ “$1” = “Workers” ]]; then
- wget –quiet -O – http://127.0.0.1/server-status?auto | grep Score | grep -o “\.” | wc -l
- else
- wget –quiet -O – http://127.0.0.1/server-status?auto | head -n 9 | grep $1 | awk -F “:” ‘{print $2}’
- fi
- vim /etc/zabbix/zabbix_agentd.d/apache.conf
- UserParameter=apache[*],/etc/zabbix/shell/apache_status.sh $1
重启 zabbix-agent 测试
[root@localhost ~]# zabbix_get -s 127.0.0.1 -k apache[Uptime]
17
17
最后在 Zabbix Server 端导入模板并关联