欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

web压力测试 压力测试webbench

程序员文章站 2024-03-23 16:20:40
...

公司游戏提交到sina微博平台,同时还需要提供一份压力测试报告,因为没有压力测试的经验,所以查了不少资料,走了不少弯路,做一个总结,分享给大家吧

 

首先我们只有1台服务器,8G内存,操作系统centos5.5(64位),安装了Mysql 5.5,Apache 2.2.17,TC 1.4.47,TT 1.1.41,PHP 5.3.5,这么多的软件都跑在一台机子上,着实有点担心伤不起啊

 

选择web压力测试软件的时候,做了一番选择,有ab,siege,最终还是选择了webbench,理由是webbench开源免费,安装方便,可以模拟高达3w的并发,同时参数简单,省去了不少研究的功夫

 

webbench的官网是:http://home.tiscali.cz/~cz210552/webbench.html

同时介绍比较详细的网址有:http://blog.s135.com/post/288/

 

1.安装先

#wget http://home.tiscali.cz/~cz210552/distfiles/webbench-1.5.tar.gz
#tar -zxvf webbench-1.5.tar.gz
#make
#make install

 

2.写一段php代码,包含了经常调用且需要操作mysql,tt,假设url是 http://mytest.com/

 

开始测试前,还需要几个准备工作

3.写一个shell脚本ps.sh,记录每秒的http请求数

#!/bin/sh

while [ 1 ]
do
ps aux | grep httpd | wc -l
sleep 1
done

4.再写一个shell脚本ms.sh,记录每秒最高的请求数

#!/bin/bash

m=0
while [ 1 ]
do
c=$(ps aux | grep httpd | wc -l)
if [ $m -lt $c ]; then
m=${c}
echo $m
fi
sleep 1
done

 

5.给shell脚本权限后,开启2个远程窗口,分开运行脚本

#chmod +x ps.sh
#./ps.sh

 

#chmod +x ms.sh
#./ms.sh

 

6.开启新窗口,查看内存和cpu使用情况

#top
 

7.开启新窗口,webbench压力测试,8000的并发,持续30秒

#webbench -c 8000 -t 30 http://mytest.com/
 

8.得到结果,各自的操作窗口的数据进行总结了

 

9.优化apache的并发配置,加上了自己的注释

// 注释: 查看编译的模块
// 这里是查看是否编译prefork.c

#/usr/local/apache/bin/apachectl -l

Compiled in modules:
  core.c
  prefork.c
  http_core.c
  mod_so.c
// 编辑httpd.conf
#vi /usr/local/apache/conf/httpd.conf

// 去掉“#”
# Server-pool management (MPM specific)
Include conf/extra/httpd-mpm.conf
// 编辑httpd-mpm.conf
#vi /usr/local/apache/conf/extra/httpd-mpm.conf

// 刚才看到是prefork.c,这里就派上用场了
// 编辑prefork模块
<IfModule mpm_prefork_module>
    // 启动apache同时产生10个进程
    StartServers        10

    // 最少50个空闲进程,理解最少50个候补人员,供apache差遣
    MinSpareServers     50

    // 最多100个空闲进程,如果少于MinSpareServers,则在MinSpareServers基础上+1
    MaxSpareServers     100

    // 此项如果不存在,自行添加,如果允许最大客户端超过256个,此项必须设置,必须在MaxClients之前,必须大于MaxClients
    ServerLimit         3000

    // 允许的最大并发数
    MaxClients          3000

    // 每个并发数允许的最多子进程,如果超过,会直接杀死进程
    MaxRequestsPerChild 1000
</IfModule>

配置好apache后,记得重启,先stop在start比较保险

#/usr/local/apache/bin/apachectl stop
#/usr/local/apache/bin/apachectl start
 

10.调整心得

  1. StartServers 主要是考虑如果少于MinSpareServers,则会每秒按2的倍数生成1个新的空闲进程,就是1生2,2生4,4生8,直到达到MinSpareServers,所以和MinSpareServers相关
  2. MinSpareServers 开始设置得很大,对于一下子有大量的并发http效果明显,但是如果没有过大的http并发请求,则该项会占用内存和cpu,所以要慢慢调节到需要的量即可
  3. ServerLimit 据说最大值是20000,么尝试过
  4. MaxClients 并发数,如果设置太小,则超过并发数的请求只能排队等待,影响体验,当然,如果设置太大,则会增加服务器负担,使得每个得到处理的请求的体验也下降,难呐
  5. MaxRequestsPerChild 默认是0 表示所有子进程都会进行完后才会删除,所以很多人建议是设置一个定值

 

11.总结

总算把报告提交上去了,也不知道能不能通过