性能测试工具 wrk

一、简介

  WRK 是一款针对HTTP基准测试工具,即使在单个多核CPU上运行时,也能够对目标机器产生大量负载。原因是它使用了一些操作系统特定的高性能 io 机制, 比如 select, epoll, kqueue 等。其实它是复用了 redis 的 ae 异步事件驱动框架。说说 wrk 的优缺点吧:

优点:单机并发能力强,极少的线程数即可模拟大量的并发请求。

缺点:不支持分布式,对于上万用户的并发测试显得力不从心。lua 脚本学习成本较高。

 

二、安装

 执行以下命令:

git clone https://github.com/wg/wrk.git
cd wrk
make
cp wrk /usr/local/bin           # 将可执行文件移动到 /usr/local/bin ,方便调用

 输入 wrk -v 检查安装是否成功

 

三、测试

 一、get 请求

 执行命令:

wrk -t12 -c100 -d10s --timeout=30s --latency https://www.baidu.com

 这条压测命令代表:12个线程 100个 tcp 持续对 https://www.baidu.com 压测10s,超时时间为30s

 

压测结果:

 wrk 各项参数详解:

-c, --connections       # tcp 连接数
-d, --duration          # 压测持续时间
-t, --threads           # 线程数
-s, --script            # 指定 lua 脚本
-H, --header            # 为每个HTTP请求添加 hearder
     --latency          # 压测结束后,打印延时统计信息
     --timeout          # 超时时间
-v, --version           # 打印 wrk 详细信息 

 

 注意:线程数不易设置的过高,官方建议一般为 CPU 核心数的2到4倍最佳,高了会因频繁切换线程而降低效率。wrk 不是一个连接对应一个线程的模型,而是通过异步网络 io 提升并发量,也就说是一个线程能管理创建多个 tcp 连接。这就是 wrk 为什么足够轻量级,但却可以模拟出大量 tcp 连接的原因。

 

二、 post 请求

 wrk 支持 lua, post 请求压测需要借助 lua 脚本,编写脚本,保存 .lua 格式文件

wrk.method = "POST"

wrk.headers["Content-Type"] = "application/json"

# 需要传的参数
wrk.body = ""

执行压测命令:

wrk -t2 -c10 -d5s --timeout=30s --latency  -s post.lua https://xxx.xxx.xxx

 

压测结果:

 

posted @ 2020-03-06 09:56  三只松鼠  阅读(2347)  评论(0编辑  收藏  举报