Siege是一款开源的压力测试工具,设计用于评估WEB应用在压力下的承受能力。可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。siege可以从您选择的预置列表中请求随机的URL。所以siege可用于仿真用户请求负载
Siege官网:http://www.joedog.org/Siege下载:wget http://www.joedog.org/pub/siege/siege-latest.tar.gz
#由于Siege不提供windows版本,但是有人通过Cygwin(Cygwin是一个在windows平台上运行的类UNIX模拟环境,让你的windows拥有Linux环境)基于Linux版的编译成windows版本:
#地址为 https://github.com/ewwink/siege-windows
#1 下载siege-windows-3.0.5.zip
#2 解压到 C:\siege-windows (注意路径必须是这个,解压后文件夹名如果不是这个,要更改文件夹名,并放到c盘下)
#3 就可以愉快的使用了(当然你可以把该路径加入到环境变量中)
#1 下载
wget http://www.joedog.org/pub/siege/siege-latest.tar.gz
#2 解压
tar -zxvf siege-latest.tar.gz
#3 切到目录下编译
cd siege-3.1.4/
./configure
make
make install
#4 默认安装在/usr/local/bin/,并自动添加到系统环境变量中,在终端输入siege 如果可以显示出相应的命令介绍,则表示我们已经安装成功
# 0、-c 100表示并发模拟100个用户并发,-r 10表示重复运行10次
siege -c 100 -r 10 http://www.baidu.com
# 1、 启动100个用户(线程)在5分钟内对某一页面www.zihou.me进行并发访问
siege http://www.baidu.com -c200 -t5
# 2、 对多个页面进行并发访问
新建一个文件urls,里面的内容为(只是例子,任何url都可以):
http://www.zihou.me
http://www.zihou.me/2010/12/16/2821/
http://www.zihou.me/2010/12/14/2806/
siege -f urls -c200 -t5
表示启动200个用户在5分钟内并发访问以上的url网址。
# 3、 指定http请求头 文档类型
siege -H "Content-Type:application/json" -c 200 -r 100 -f urls.txt -i -b
# 4、 发送post请求,在网址后添加POST说明,并且紧跟参数在其后
siege -c 100 -r 100 http://www.baidu.com/ POST k1=v1&k2=v2
-C,或–config 在屏幕上打印显示出当前的配置,配置是包括在他的配置文件$HOME/.siegerc中,可以编辑里面的参数,这样每次siege 都会按照它运行.
-v 运行时能看到详细的运行信息
-c n,或–concurrent=n 模拟有n个用户在同时访问,n不要设得太大,因为越大,siege 消耗本地机器的资源越多
-i,–internet 随机访问urls.txt中的url列表项,以此模拟真实的访问情况(随机性),当urls.txt存在是有效
-d n,–delay=n hit每个url之间的延迟,在0-n之间
-r n,–reps=n 重复运行测试n次,不能与 -t同时存在
-t n,–time=n 持续运行siege ‘n’秒(如10S),分钟(10M),小时(10H)
-l 运行结束,将统计数据保存到日志文件中siege .log,一般位于/usr/local/var/siege .log中,也可在.siegerc中自定义
-R SIEGERC,–rc=SIEGERC 指定用特定的siege 配置文件来运行,默认的为$HOME/.siegerc
-f FILE, –file=FILE 指定用特定的urls文件运行siege ,默认为urls.txt,位于siege 安装目录下的etc/urls.txt
-u URL,–url=URL 测试指定的一个URL,对它进行”siege “,此选项会忽略有关urls文件的设定
Transactions: 30000 hits //完成30000次处理
Availability: 100.00 % //100.00 % 成功率
Elapsed time: 68.59 secs //总共使用时间
Data transferred: 817.76 MB //共数据传输 817.76 MB
Response time: 0.04 secs //响应时间,显示网络连接的速度
Transaction rate: 437.38 trans/sec //平均每秒完成 437.38 次处理
Throughput: 11.92 MB/sec //平均每秒传送数据
Concurrency: 17.53 //实际最高并发连接数
Successful transactions: 30000 //成功处理次数
Failed transactions: 0 //失败处理次数
Longest transaction: 3.12 //每次传输所花最长时间
Shortest transaction: 0.00 //每次传输所花最短时间
当我们需要模拟大并发情况下的压测,则需要开启数量可观的线程,以及要占用大量的文件描述符,而系统默认对能够使用的文件描述符数量做了限制。首先使用 ulimit -a
命令查看目前系统开启的文件描述符数量
-t: cpu time (seconds) unlimited
-f: file size (blocks) unlimited
-d: data seg size (kbytes) unlimited
-s: stack size (kbytes) 8192
-c: core file size (blocks) 0
-v: address space (kbytes) unlimited
-l: locked-in-memory size (kbytes) unlimited
-u: processes 1418
-n: file descriptors 256
# 可以看到目前系统允许使用的文件描述符的数量为 256,这是远远不够的。如果不修改该参数,要是进行大量并发的模拟场景时则会报TOO MANY FILES OPEN 错误。为此我们可以先使用 ulimit -n 10000命令来调大系统可打开的文件描述符数量