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
//我的是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个工作设置的参数
<IfModule mpm_prefork_module>
StartServers 5 启始状态生成多少个进程
MinSpareServers 5
MaxSpareServers 10
MaxRequestWorkers 250
MaxConnectionsPerChild 0
</IfModule>
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的进程
//意思就是这里是初始只有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
//由于是静态页面,cpu就直接忽略吧。加大压力。
//可以去看usr/local/httpd/htdocs/test.html 这个网页
//失败请求0个。不错
//那么,来狠一点请求1300 并发550,那个最大链接数改为300
<IfModule mpm_prefork_module>
StartServers 50
MinSpareServers 50
MaxSpareServers 100
ServerLimit 300
MaxRequestWorkers 300
MaxConnectionsPerChild 0
</IfModule>
//改了,记得停,关了,再开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
连接数已经达到了300了。还以设置更大
我的阿里云是1G内存。60%内存。感觉这样,就差不多了。我没打算我的破网站搞这么多人来访问。
额,来玩疯狂点的。
./ab -n 3000 -c 550-t 60 -w http://192.168.07/ > /usr/local/httpd/htdocs/test.html
<IfModule mpm_prefork_module>
StartServers 50
MinSpareServers 50
MaxSpareServers 100
ServerLimit 400
MaxRequestWorkers 400
MaxConnectionsPerChild 50
</IfModule>
//连接数变成400,子进程超过50之后干掉
//MaxConnectionsPerChild,子进程大于50直接干掉。卧槽这货写0是不应该的。妈的,耐心准备都没有了,ab有时候测试会出问题。直接断了。草啊,来回测试写个100。
//后面来加上一句话的,就是子进程可能是很多50不够用,ab测试很高压力一直有点问题。估计0还行。默认不限。
/usr/local/httpd/bin/apachectl stop
/usr/local/httpd/bin/apachectl start
//下面的有结果,
//上面的是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的工作模式了
<IfModule mpm_worker_module>
StartServers 20 //启始状态生成多少个进程
MinSpareThreads 50 //最小空闲线程
MaxSpareThreads 200 //最大空闲线程
ServerLimit 50 //进程数上限 ,最大2万
MaxRequestWorkers 5000( 也就是 MaxClients,允许同时连入的请求数,超过将排队 ) ThreadsPerChild 100 //每个进程包含多少个线程 独立处理请求 ThreadLimit 200 //限制一个进程最多生成200个线程 MaxConnectionsPerChild 1000//一个进程一共接受过1000次请求之后被杀死。以释放内存
</IfModule> ServerLimit* ThreadsPerChild >= MaxRequestWorkers MaxRequestWorkers 必须是ThreadsPerChild 的整数倍
//event就是worker的加强版。自己去测试来自虐吧。
//还有更多优化方式mysql,一台服务器不行后,多来几台,负载均衡。
//还有,实际情况会有很多的不同。不同的因素会影响,这里都没有写什么代码。
//prefork的稳定,就是很不错了。谁希望打开一个网页403.
//就这样了。