前言
Siege 是一个回归测试和基准测试的程序. 它旨在让开发人员在压力下测试性能, 了解系统的承受能力.
Siege 支持 HTTP、HTTPS 协议.
Siege 可以配置一定数量的客户端并发访问服务器.
注意: 由于Siege依赖于Microsoft不支持的POSIX.1b功能, 不支持 windows 平台
安装
系统环境: Mac OS
安装 openssl , 不需要 https 的可以绕过当前步骤
下载地址:https://github.com/openssl/openssl
git clone https://github.com/openssl/openssl
cd openssl
./config --prefix=/usr/local/openssl
make
make install
openssl version
安装 Siege
下载地址:http://download.joedog.org/siege/siege-4.0.4.tar.gz
tar zxvf siege-4.0.4.tar.gz
cd siege-4.0.4
make clean
./configure --prefix=/usr/local/siege --with-ssl=/usr/local/openssl
make
make install
注意: siege 默认只支持255个并发数,可以自己自定义,修改 ~/.siege/siege.conf 下的 limit 数值。
注意: 在用户目录下的 .bash_profile 中的末尾加入 ulimit -n 2000 , 保存后再执行 source ~/.bash_profile 即可
命令参数
参数 | 描述 |
---|---|
-V, --version | 打印版本号 |
-h, --help | 打印帮助信息 |
-C, --config | 打印当前配置信息 |
-g, --get | 拉取http头信息 |
-p, --print | 打印整个页面的内容 |
-c, --concurrent=NUM | 并发用户数量,默认10个 |
-r, --reps=NUM | 运行次数 |
-t, --time=NUMm | 在选定的时间段内运行测试 格式为“NUMm”,其中NUM是时间单位,“m”修饰符是S、M或H,分别表示秒、分钟和小时。 例如: -t3600S,-t60M,-t1H |
-d, --delay=NUM | 每个模拟请求在1-N之间随机延迟秒数. |
-b, --benchmark | 基准测试, 请求没有延迟 |
-i, --internet | 模拟网络用户随机点击URL此选项与配置文件一起使用,该文件是包含许多URL的文件。 使用此选项,每个用户每次点击服务器时都会随机点击文件中的任何URL。 |
-f, --file=FILE | 选择指定的URL文件 默认文件地址是 SIEGE_HOME/etc/urls.txt |
-R, --rc=FILE | 指定siegerc文件 |
-l, --log[=FILE] | 日志文件,默认是 PREFIX/var/siege.log |
-H, --header="text" | 给请求添加头,支持多个 |
-A, --user-agent="text" | 给请求设置User-Agent |
-T, --content-type="text" | 给请求设置Content-Type |
性能参数
参数 | 描述 |
---|---|
Transactions | 事务命中次数 案例: -c10 -r2 , 总共20个命中次数 因为遵循的浏览器规范, 所以如果目标页面有多个请求, 那么统计次数会超过预定的数值 |
Availability | 服务器成功处理的套接字连接的百分比 |
Elapsed time | 整个测试持续的时间,从第一个开始到最后一个结束 |
Data transferred | 整个测试传输数据的总和 (包括标题信息以及内容) |
Response time | 每个请求所花费的平均响应时间。 |
Transaction rate | 简而言之,服务器每秒能够处理的平均事务数:事务命中次数除以持续的时间。Transactions / Elapsed time |
Throughput | 吞吐量是从服务器到所有请求用户每秒传输的平均字节数 |
Concurrency | 平均同时连接数,该数量随着服务器性能下降而增加。 |
Successful transactions | 成功事务次数 |
Failed transactions | 失败事务次数 |
Longest transaction | 最长事务时间 |
Shortest transaction | 最短事务时间 |
应用举例
1.基础应用
siege -c10 -r1 url
2.支持 header 参数
siege -c10 -r1 -p --header="Authorization: Bearer b7c75bae-9d68-4a74-bffb-95eb08a40918" --header="sg: 123456"
3.支持 application/json 方式请求
siege -c1 -r1 "[http://192.168.16.101:6005/bpm/processInstances/review](http://192.168.16.101:6005/bpm/processInstances/review) PUT <./1.json "
4.支持从文件读取url
siege -c9 -r1 -f url.txt