httpd的性能测试工具ab和httpd三种工作模式

HTTPD它自带有一个测试工具,就是ab我的编译安装的。路径是这个/usr/local/httpd/bin。里面就有个ab。
-n 请求数
-c 并发数
-t xx秒 (上述请求,多少时间内执行完)
-w 以HTML表的格式输出结果
-p 包含了需要POST的数据的文件

(还有很多自己百度吧,谷歌也行)
./ab -n 100 -c 200 -t 60 -w http://localhost > /usr/local/httpd/htdocs/test.html
解释一下:就是执行 ./ab ,请求是100 , 并发是200 , 时间是60秒(一分钟) -w以HTML文件输出结果 > /usr/local/httpd/htdocs/test.html 放到这个路径的html里面
那个网址,写你要测试的网站。

Apache目前一共有三种稳定的MPM(Multi-Processing Module,多进程处理模块)模式。
它们分别是prefork,worker和event。

三种工作模式--prefork

prefork apache 2.2默认的模式。没有线程的概念,是多进程模型,一个进程处理一个连接;稳定;响应快。其缺点是在连接数比较大时就非常消耗内存。
2.2中编译时不加--with-mpm=xxx 那么就是prefork 2.4中 则是 event工作模式

三种工作模式--worker

多进程多线程模型,一个进程有多个线程,每个线程处理一个连接。这种模式下开销更小,处理的请求更海量。
缺点是一旦某个线程出了问题,其所属进程也可能会死掉

三种工作模式--event
Worker模式的升级和加强版本.相对worker模式能够承受的了更高的并发负载。
event模式不能很好的支持https的访问

//看看自己的是什么模式吧。去/usr/local/httpd/bin。
./apachectl -l

httpd的性能测试工具ab和httpd三种工作模式_第1张图片

//我的是event.c

./configure --prefix=/usr/local/httpd --enable-MODULE=shared --with-mpm=
prefork

--with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util
make && make install

//重新安装,改为prefork模式,--with-mpm=prefork
//然后./apachectl -l 看看是不是有prefork.c有就下一步。

cd /usr/local/httpd/conf //跑到配置目录
vim vim httpd.conf //修改这个配置文件

#Include conf/extra/httpd-mpm.conf 把 #号去掉,改配置文件,要重启才有效果。

cd /usr/local/httpd/conf/extra //看里面的东西
vim httpd-mpm.conf //会看见mpm_prefork_module worker event其实就是3个工作设置的参数


StartServers 5 启始状态生成多少个进程
MinSpareServers 5
MaxSpareServers 10
MaxRequestWorkers 250
MaxConnectionsPerChild 0

MinSpareServers 最小空闲进程数
MaxSpareServers 最大空闲进程数,如果空闲进程数大于这个值,Apache会自动kill掉一些多余进程
MaxRequestWorkers 最大接收的请求数,apache 2.3.1之前叫做MaxClients. 默认值256(250?).调大这个值要增加ServerLimit (最大为2万,要调这个值要改源码文件)

MaxRequestsPerChild(2.4为MaxConnectionsPerChild) 每个子进程可处理的请求数。每个子进程在处理了“MaxRequestsPerChild”个请求后将自动销毁 。0为不限制

ps -ef | grep httpd //来查看现在开启多少个httpd的进程


httpd的性能测试工具ab和httpd三种工作模式_第2张图片

//意思就是这里是初始只有5个,对应了StartServers 5

//来玩个有意思的 来试试看
StartServers 1 启始数量1
MinSpareServers 1 空闲数量1

/usr/local/httpd/bin/apachectl restart //重启httpd
ps -ef | grep httpd | grep -v grep //看一下httpd的进程


额~其实就是变成1个了,root用户的他管不了。daemon 恶魔??? 这货才是httpd用户
ps -ef | grep httpd | grep -v grep | grep -v root | wc -l //这样自己不用数数了,数字直接出来,自己试试看吧。

//接下来要算一下httpd使用的内存,和CPU。
ps aux //可以查看进程ID和CPU 和 内存等
ps aux | grep httpd //可以看到httpd的内存和cpu占用的状况
ps aux | grep httpd | grep -v grep | grep -v root //排除grep和root

wc -l //文件的行数

awk 里面有个很牛逼的语法
awk 'BEGING{sum=0;} {sum+=$4;}END{print sum}'
//BEGIN{xxx} 用于初始状态设置初始值
//END 结束状态 执行某些事

ps aux | grep httpd | grep -v grep | awk 'BEGING{sum=0;} {sum+=$3;}END{print sum}' //内存 $3
ps aux | grep httpd | grep -v grep | awk 'BEGING{sum=0;} {sum+=$4;}END{print sum}' //CPU $4
ps aux | grep httpd | grep -v grep | wc -l //行数

vim hehe //写个脚本,chmod +x hehe个个X权限

HTTPD_MEM=`ps aux | grep httpd | grep -v grep | awk '{sum+=$4}END{print sum}'`
HTTPD_CPU=`ps aux | grep httpd | grep -v grep | awk '{sum+=$3}END{print sum}'`
HTTPD_NUM=`ps aux | grep httpd | wc -l`
echo "HTTPD_MEM is $HTTPD_MEM"
echo "HTTPD_CPU is $HTTPD_CPU"
echo "HTTPD_NUM is $HTTPD_NUM"

//后面的是耐心的测试

./ab -n 100 -c 200 -t 60 -w http://192.168.07/ > /usr/local/httpd/htdocs/test.html

httpd的性能测试工具ab和httpd三种工作模式_第3张图片

//由于是静态页面,cpu就直接忽略吧。加大压力。

httpd的性能测试工具ab和httpd三种工作模式_第4张图片

//可以去看usr/local/httpd/htdocs/test.html 这个网页
//失败请求0个。不错

//那么,来狠一点请求1300 并发550,那个最大链接数改为300

StartServers 50
MinSpareServers 50
MaxSpareServers 100
ServerLimit 300
MaxRequestWorkers 300
MaxConnectionsPerChild 0

//改了,记得停,关了,再开httpd服务,要求ps -ef | grep httpd | wc -l //小于5

./ab -n 1300 -c 550-t 60 -w http://192.168.07/ > /usr/local/httpd/htdocs/test.html

httpd的性能测试工具ab和httpd三种工作模式_第5张图片
httpd的性能测试工具ab和httpd三种工作模式_第6张图片

连接数已经达到了300了。还以设置更大
我的阿里云是1G内存。60%内存。感觉这样,就差不多了。我没打算我的破网站搞这么多人来访问。

额,来玩疯狂点的。
./ab -n 3000 -c 550-t 60 -w http://192.168.07/ > /usr/local/httpd/htdocs/test.html

StartServers 50
MinSpareServers 50
MaxSpareServers 100
ServerLimit 400
MaxRequestWorkers 400
MaxConnectionsPerChild 50

//连接数变成400,子进程超过50之后干掉

//MaxConnectionsPerChild,子进程大于50直接干掉。卧槽这货写0是不应该的。妈的,耐心准备都没有了,ab有时候测试会出问题。直接断了。草啊,来回测试写个100。
//后面来加上一句话的,就是子进程可能是很多50不够用,ab测试很高压力一直有点问题。估计0还行。默认不限。

/usr/local/httpd/bin/apachectl stop
/usr/local/httpd/bin/apachectl start

//下面的有结果,

httpd的性能测试工具ab和httpd三种工作模式_第7张图片
httpd的性能测试工具ab和httpd三种工作模式_第8张图片

//上面的是MaxConnectionsPerChild 100

//额~有点没耐心,继续写完吧。-n 3000 -c 550,这个不是我这个低配置能干的事情。阿里云最低配置。额~你们也根据自己的配置写。没有统一的配置。内存与CPU自己根据自己的机子来安排。我的网站不想让太多人访问所有都写2。

//worker 工作方式

./configure --prefix=/usr/local/httpd --enable-MODULE=shared --with-mpm=
worker

--with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util
make && make install

./apachectl -l //来看看自己的工作模式

//这样就变成了worker的工作模式了


StartServers 20 //启始状态生成多少个进程
MinSpareThreads 50 //最小空闲线程
MaxSpareThreads 200 //最大空闲线程
ServerLimit 50 //进程数上限 ,最大2万
MaxRequestWorkers 5000( 也就是 MaxClients,允许同时连入的请求数,超过将排队 ) ThreadsPerChild 100 //每个进程包含多少个线程 独立处理请求 ThreadLimit 200 //限制一个进程最多生成200个线程 MaxConnectionsPerChild 1000//一个进程一共接受过1000次请求之后被杀死。以释放内存
ServerLimit* ThreadsPerChild >= MaxRequestWorkers MaxRequestWorkers 必须是ThreadsPerChild 的整数倍

//event就是worker的加强版。自己去测试来自虐吧。

//还有更多优化方式mysql,一台服务器不行后,多来几台,负载均衡。
//还有,实际情况会有很多的不同。不同的因素会影响,这里都没有写什么代码。
//prefork的稳定,就是很不错了。谁希望打开一个网页403.
//就这样了。

你可能感兴趣的:(httpd的性能测试工具ab和httpd三种工作模式)