性能调优的瑞士军刀

背景

接口功能开发结束之后,要考虑必定的非功能需求,比方并发数,稳定性;

或许系统上线之后,都某些接口或许根据某个指标做了调优,需求比照优化前后的作用;

这个时分就需求压测东西了,协助你构建很多的恳求,很多的并发来检测你的接口;

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

业界比较轻量的压测东西有 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

已经制造好的镜像

镜像地址: 放到了公网;需求的能够直接拿来运用;无需账号暗码;

地址: hub.docker.com/repository/…

docker pull carter880522hn/app:abtest

你也能够方便的在你的k8s集群快速拉起一个pod,对你的容器运用进行功能比照压测,

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

性能调优的瑞士军刀

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

性能调优的瑞士军刀

东西测试

1 curl测试

curl http://10.0.6.71:32638/echo

下面是测试作用,这样你就能够快速的勘探某个http接口是否晓畅;

性能调优的瑞士军刀

2 wrk测试

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

里面有各种lua脚本编写测试用例的比如,能够copy下来,修改一下就能够运用;

github地址: github.com/wg/wrk

先来直观感受一下。根本运用:

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

-t 线程
-c 并发数
-d 持续时刻
最终是接口地址

下图是它自带的运用参数阐明。

性能调优的瑞士军刀

参数意义:

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测试

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

性能调优的瑞士军刀

-n 100个恳求
-c 10个并发
-t时刻约束
-s 恳求呼应超时时刻

下面是一个比如:

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

成果

性能调优的瑞士军刀

小结

供给了东西镜像,方便测试;测试结束之后,把功能测试回来的参数整理成表格,生成折线图,能够供给给到评价方快速描述功能优化的成果和价值。

原创不易,关注诚可贵,转发价更高!转载请注明出处,让我们互通有无,共同进步,欢迎沟通交流。