Centos6.5使用Siege压力测试

Siege是一个压力测试和评测工具,设计用于WEB开发这评估应用在压力下的承受能力:可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。

Siege是一个多线程http负载测试和基准测试工具,完全使用C语言实现,可以对HTTP和FTP服务器进行负载和性能测试。通过使用Siege 提供的功能,可以很容易的制定测试计划:包括规定使用并发用户数、重复数量,从而可以模拟在服务器、网络或者其它对象上附加负载以测试他们提供服务的受压能力,方便的测试服务器的性能。最后,利用Siege提供的测试结果来分析性能指标或者分析他们提供的服务在不同负载条件下的性能情况,分析测试结果,找出影响系统性能的瓶颈。


官方网址:http://www.joedog.org/

Centos6.5使用Siege压力测试_第1张图片


安装siege

安装解压:tar zxvf siege-3.1.3.tar.gz,进入到解压后的目录:cd siege-3.1.3

运行命令:
Centos6.5使用Siege压力测试_第2张图片

./configure
make
make install

安装完毕后如果有错误,则按照提示信息处理即可(有可能会出现错误,我安装的时候就报了错,不过有很清楚地提示信息)。
输入:siege –help,如果安装没问题会出现以下类似信息:

Centos6.5使用Siege压力测试_第3张图片

上面也是运行的一些参数,右边是对一些参数的解释说明
比如:
–C :查看siege当前的配置信息
–V:版权说明信息
–c:并行启动(访问)用户数,默认是10
-t:压力测试时间,比如-t5表示持续时间是5分钟
-r:每个连接发出的请求数量,这个与t有些类似,所以设置了这个值就不需要设置t了,反之亦然。
-f:对应一个文件,这个文件里每一行为一个URL链接,格式如:
www.xxx.com

www.xxx.com/login

www.xxx.com/register
........


好了,主要的一些参数说明就介绍这么多,其余的可以参考上面的英文提示。


使用siege
1、  启动500个用户(线程)在5分钟内对某一页面www.xxx.com进行并发访问
siege http://www.xxx.com -c500 -t5


2、  对多个页面进行并发访问
新建一个文件urls,里面的内容为测试URL:

www.xxx.com

www.xxx.com/login

www.xxx.com/register


siege -f urls -c500 -t5
表示启动500个用户在5分钟内并发访问以上的url网址。




并发测试完毕后,会打印出一些结果信息:

Centos6.5使用Siege压力测试_第4张图片


Transactions:             
完成8334次点击
Availability:                98.94 % 
成功率 
Elapsed time:            299.17 secs 
总共用时
Data transferred:      343.64MB 
共数据传输:343.64兆
Response time:         8.48 secs 
相应用时8.48秒:显示网络连接的速度
Transaction rate:      27.86 trans/sec 
平均每秒完成27.86次点击:表示服务器后台处理的速度
Throughput:              1.15 MB/sec 
平均每秒传送数据:1.15兆
Concurrency:             236 
最高并发数 236个
Successful transactions: 8334 
成功处理次数8334个
Failed transactions: 86 
失败处理次数89个

Shortest   transaction:     69.84 最短事务

Longest transaction:     69.84 最长事务

如果在并发的过程中,被访问的页面打开出错或及其缓慢,表示在当前并发条件下,被访问网站是不能承受的,也就是抗并发能力弱。

辅助工具: 
增量压力测试: 

为了方便增量压力测试,siege还包含了一些辅助工具:
bombardment (1) 
是一个辅助工具:用于按照增量用户压力测试: 
使用样例: 
bombardment urlfile.txt 5 3 4 1
初始化URL列表:urlfile.txt
初始化为:5个用户 
每次增加:3个用户 
运行:4 
每个客户端之间的延迟为:1 

输出成CSV格式: 
siege2csv.pl (1) 
siege2csv.pl
bombardment的输出变成CSV格式: 
Time Data Transferred Response Time Transaction Rate Throughput Concurrency Code 200 (note that this is horribly broken.) 


另外,在并发的过程中最好通过top命令来查看CPU和Memory的占用情况。


你可能感兴趣的:(linux)