性能调优的瑞士军刀

file

背景

接口功能开发完毕之后,要考虑一定的非功能需求,比如并发数,稳定性;

或者系统上线之后,都某些接口或者基于某个指标做了调优,需要对比优化前后的效果;

这个时候就需要压测工具了,帮助你构建大量的请求,大量的并发来检测你的接口;

针对对比数据,来进行进一步的调优,然后拿到数据之后,展现你调优的价值。

业界比较轻量的压测工具有 ab,wrk;

方便对高性能高并发要求的接口进行压测和对比性能提升;

工具准备

Dockerfile

跟其它工具不同,我提供给你的不是各种官网下载地址,安装步骤,我给的是一个开箱即用的瑞士军刀。

这里制作了一个镜像,里面默认安装了ab,wrk,bash工具,方便进行操作。

带了bash,curl工具,方便定位网络问题;

下面是Dockerfile,你还可以更改和添加你所需的其它的各种工具。

FROM openjdk:8-jdk-alpine
RUN apk add --no-cache bash
RUN apk add --no-cache curl
RUN apk add --no-cache wrk
RUN apk add --no-cache apache2-utils

WORKDIR /app

ENTRYPOINT ["/bin/bash","top"]

制作镜像步骤

//制作本地镜像
docker build -t ab:v1 .

//输入你的docker hub账号和密码之后
docker login

//制作推送的远程镜像tag
docker tag ab:v1 carter880522hn/app:abtest

//推送镜像
docker push carter880522hn/app:abtest

已经制作好的镜像

镜像地址: 放到了公网;需要的可以直接拿来使用;无需账号密码;

地址: https://hub.docker.com/repository/docker/carter880522hn/app/general

docker pull carter880522hn/app:abtest

你也可以方便的在你的k8s集群快速拉起一个pod,对你的容器应用进行性能对比压测,

登录进到容器,即可进行交互式操作;

file

下图是进入容器之后的控制台

file

工具测试

1 curl测试

curl http://10.0.6.71:32638/echo

下面是测试效果,这样你就可以快速的探测某个http接口是否通畅;

file

2 wrk测试

比较还是安装正规的wrk工具,我也放一下源代码地址,

里面有各种lua脚本编写测试用例的例子,可以copy下来,修改一下就可以使用;

github地址: https://github.com/wg/wrk

先来直观感受一下。基本使用:

wrk -t 10 -c 10 -d10s http://10.0.6.71:32638/echo

-t 线程数<br />-c 并发数<br />-d 持续时间 <br /> 最后是接口地址

下图是它自带的使用参数说明。

file

参数含义:

Usage: wrk <options> <url>                            
  Options:                                            
    -c, --connections <N>  Connections to keep open     保持打开的连接数
    -d, --duration    <T>  Duration of test             测试时长,单位有s,f,h
    -t, --threads     <N>  Number of threads to use     使用的线程数量
                                                      
    -s, --script      <S>  Load Lua script file         使用的lua脚本位置
    -H, --header      <H>  Add header to request        添加请求头
        --latency          Print latency statistics     打印延迟统计数据
        --timeout     <T>  Socket/request timeout       设置socket的超时时间
    -v, --version          Print version details        打印版本信息
                                                      
  Numeric arguments may include a SI unit (1k, 1M, 1G)

完整一点参数的使用例子:

wrk -c 1 -d 60s -t 1 --latency --timeout 3s    http://10.0.6.71:30281/echo

响应结果分析示例:

Running 1m test @ http://10.0.6.71:30281/echo     运行了1分钟
  1 threads and 1 connections                     1个线程1个连接
  Thread Stats   Avg      Stdev     Max   +/- Stdev     线程数据  单个线程平均延迟   方差 最大延迟  偏差比例
    Latency     4.04ms  349.84us  18.52ms   96.59%      延迟
    Req/Sec   248.76      8.07   262.00     74.17%      请求数量/秒
  Latency Distribution                                  延迟分布
     50%    3.97ms                                       50% 响应时间 3.97毫秒
     75%    4.05ms                                       75% 响应时间 4.05毫秒
     90%    4.17ms                                       90% 响应时间 4.17毫秒
     99%    5.18ms                                       99% 响应时间  5.18毫秒   
  14871 requests in 1.00m, 1.56MB read           一分钟内发送了14871个请求,响应数据体积:1.58MB
Requests/sec:    247.72                          请求吞吐量: 247.72/秒
Transfer/sec:     26.61KB                        数据交换量: 26.61KB/秒

写lua脚本例子:不需要安装lua环境;

a.lua

wrk.method = "POST"
wrk.body   = "foo=bar&baz=quux"
wrk.headers["Content-Type"] = "application/x-www-form-urlencoded"

测试用例:

wrk -c 1 -t 1 -d 15s -s b.post  --latency  http://172.16.0.208:8080/echo

测试结果:

Running 15s test @ http://172.16.0.208:8080/echo
  1 threads and 1 connections
  Thread Stats   Avg      Stdev     Max   +/- Stdev
    Latency     1.05ms    3.47ms  34.19ms   93.50%
    Req/Sec     5.01k   648.55     6.29k    69.33%
  Latency Distribution
     50%  175.00us
     75%  199.00us
     90%  323.00us
     99%   19.59ms
  74851 requests in 15.00s, 11.72MB read
Requests/sec:   4989.09
Transfer/sec:    799.96KB

3 ab测试

先看一下自带的使用提示:

file

-n 100个请求<br />-c 10个并发 <br /> -t时间限制 <br /> -s 请求响应超时时间

下面是一个例子:

ab -n 100 -c 10 http://10.0.6.71:32638/echo

结果

file

小结

提供了工具镜像,方便测试;测试完毕之后,把性能测试返回的参数整理成表格,生成折线图,可以提供给到评估方快速描述性能优化的结果和价值。

原创不易,关注诚可贵,转发价更高!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。
我会持续分享Java软件编程知识和程序员发展职业之路,欢迎关注!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 193,968评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,682评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,254评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,074评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 60,964评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,055评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,484评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,170评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,433评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,512评论 2 308
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,296评论 1 325
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,184评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,545评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,880评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,150评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,437评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,630评论 2 335

推荐阅读更多精彩内容