当前位置:首页 > 开发 > 开源软件 > 正文

web压力测试

发表于: 2011-08-22   作者:crizy   来源:转载   浏览:
摘要: 公司游戏提交到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,这么多的软件都跑在一台机子上,着实有点担心伤不起啊

公司游戏提交到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.总结

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

 

 

 

 

 

 

 

 

web压力测试

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号