标签:实时监控 请求 自动 httpd 三方 技术 tcp连接状态 配置文件信息 admin
apache http server(简称apache)是现在使用世界排名第一的web服务器,几乎可以应用在任何平台。它是一个开源的网页服务器,特点是简单,速度快,稳定性高,还可以作为代理服务器。
linux下 yum install httpd
service httpd start 启动
service httpd stop 停止
service httpd restart 重启
查看apache全部配置内容 cat httpd.conf|egrep -v"^.*#|^$"|nl
配置 | 解释 |
---|---|
ServerRoot "/etc/httpd" | apache的安装目录 |
Listen 80 | 监听端口 |
user apache | apache的用户默认 |
Group apache | apache的组默认 |
ServerAdmin root@localhost.com | 系统管理员邮箱 |
ServerName localhost:80 | 服务器名称 |
对根目录的限制 | |
AllowOverride none | 表示禁止用户对目录配置文件(.htaccess进行修改)重载,普通站点不建议开启 |
Require all denied | 拒绝所有来源访问 |
DocumentRoot “/var/www/html" | apache的默认web站点目录路径 |
Apache一共有3中MPM(多进程处理模块),prefork,worker,event。
Prefork MPM:在启动之初,会预派生fork一些子进程,然后等待请求进来,并且总会保持一些备用的子进程,同时派生出的每个子进程中都只有一个进程,在一个时间点内,只能处理一个请求。
worker MPM:是使用了多进程+多线程的模式。它也预先fork了几个子进程(数量比较少),每个子进程能够生成一些服务线程和一个监听线程,该监听线程监听接入请求并将其传递给服务线程处理和应答。
event MPM:event MPM中,会有一个专门的线程来管理这些 keep-alive 类型的线程,当有真实请求过来的时候,将请求传递给服务线程,执行完毕后,又允许它释放。这样,一个线程就能处理几个请求了,实现了异步非阻塞。
在配置文件添加一段Location,配置完后重启apache,访问http://ip地址/server-status
将此段代码取消注释,并修改为如下所示
ExtendedStatus On
<Location /server-status>
SetHandler server-status
Order Deny,Allow
Allow from all
</Location>
保存退出,重启 service httpd restart
定时刷新 http://ip/server-status?refresh=N,每 N 秒自动刷新一次。
采集数据 http://ip/server-status?auto
apache监控指标
linux下监控apache
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]}‘
标签:实时监控 请求 自动 httpd 三方 技术 tcp连接状态 配置文件信息 admin
原文地址:https://www.cnblogs.com/tudouxifan/p/9146690.html