mysql的ab测试工具_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

8fc63d865aef

//我的是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的进程

8fc63d865aef

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

//来玩个有意思的 来试试看

StartServers 1 启始数量1

MinSpareServers 1 空闲数量1

/usr/local/httpd/bin/apachectl restart //重启httpd

ps -ef | grep httpd | grep -v grep //看一下httpd的进程

8fc63d865aef

额~其实就是变成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

8fc63d865aef

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

8fc63d865aef

//可以去看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

8fc63d865aef

8fc63d865aef

连接数已经达到了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

//下面的有结果,

8fc63d865aef

8fc63d865aef

//上面的是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.

//就这样了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值