性能调优的瑞士军刀

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-utilsWORKDIR /appENTRYPOINT ["/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 线程数
-c 并发数
-d 持续时间
最后是接口地址

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

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/echo1 threads and 1 connectionsThread Stats   Avg      Stdev     Max   +/- StdevLatency     1.05ms    3.47ms  34.19ms   93.50%Req/Sec     5.01k   648.55     6.29k    69.33%Latency Distribution50%  175.00us75%  199.00us90%  323.00us99%   19.59ms74851 requests in 15.00s, 11.72MB read
Requests/sec:   4989.09
Transfer/sec:    799.96KB

3 ab测试

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

file

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

下面是一个例子:

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

结果

file

小结

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

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

查看全文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.dgrt.cn/a/2173414.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章:

file

性能调优的瑞士军刀

背景
接口功能开发完毕之后,要考虑一定的非功能需求,比如并发数,稳定性;
或者系统上线之后,都某些接口或者基于某个指标做了调优,需要对比优化前后的效果;
这个时候就需要压测工具了&#xf……

MPICH2简单的安装配置总结

MPICH2是MPI(Message-Passing Interface)的一个应用实现,支持最新的MPI-2接口标准,是用于并行运算的工具,在程序设计语言上支持C/C和Fortran。最近因为有项目需要的计算量比较大,所以就学习使用了MPICH2&am……

MPICH2+Eclipse开发环境的配置小结

MPICH2+Eclipse开发环境的配置小结烤鱼片(eii.dlmu)
cleverysm163.com MPICH2是MPI(Message-Passing Interface)的一个应用实现,支持C/C和Fortran,同时有linux和windows版,因此,只要是程序里没……

稀疏矩阵线性解析库SPOOLES的简单应用

稀疏矩阵线性解析库SPOOLES的简单应用烤鱼片(eii.dlmu)
cleverysm163.com SPOOLES的全称是SParse Object Oriented Linear Equations Solver,中文名大概就是面向对象的稀疏线性等式解析器。顾名思义,就是可以用来解稀疏矩阵为参数的线性方程组的数学函数……

利用MPICH2计算矩阵相乘的简单算法

利用MPICH2计算矩阵相乘的简单算法烤鱼片(eii.dlmu)cleverysm163.comMPICH2是用来进行并行运算的平台,而对矩阵算法的分解应该是并行运算应用中很常见的。今天在这里就用MPICH2写一个矩阵乘法的并行计算程序来学习一下MPICH2的使用。首先要复习一下矩阵乘法的算法&a……

CBLAS的安装与使用

CBLAS的安装与使用烤鱼片(eii.dlmu)cleverysm163.comCBLAS是BLAS的C语言接口。BLAS的全称是Basic Linear Algebra Subprograms,中文大概可以叫做基础线性代数子程序。主要是用于向量和矩阵计算的高性能数学库。本身BLAS是用Fortran写的,为了方便C/C程序的……

CLAPACK的安装与简单使用

CLAPACK的安装与简单使用烤鱼片(eii.dlmu)cleverysm163.comCLAPACK是LAPACK的C语言接口。LAPACK的全称是Linear Algebra PACKage,是非常著名的线性代数库。LAPACK是用Fortran写的,为了方便C/C程序的使用,就有了LAPACK的C接口库CLAPACK。LAPAC……

Java的二进制文件字节序转换

Java的二进制文件字节序转换烤鱼片(eii.dlmu)cleverysm163.com字节序指的是数据存储的顺序问题,分为Big-Endian和Little-Endian,Big-Endian指的是数据中的高位存储在存储器的低位,Little-Endian正好相反。Big-Endian也叫大头在前,……

MFC的DEBUG_NEW与GDI+的冲突问题

问题现象在我们使用GDI的时候,如果程序是一个MFC程序,并且是在debug模式下,那我们可能会得到如下的错误信息:
error C2660: Gdiplus::GdiplusBase::operator new : function does not take 3 parameters
原因 在debug模式下&am……

GDAL的安装

GDAL的安装烤鱼片(eii.dlmu)cleverysm163.com以VC6为例。 首先,下载gdal的安装文件,http://download.osgeo.org/gdal/gdal142.zip,解压到某目录下,如C:/gdalsrc下。 在此,我们假定VC6的安装在默认目录C:/Program Files……

深度分析Palantir的投资价值,Palantir2023年将实现强劲反弹?

来源:猛兽财经 作者:猛兽财经 在本文中,猛兽财经将通过对Palantir的股票关键指标、商业模式、盈利能力、影响Palantir2023年股价的关键利好因素等方面,对Palantir进行全面、深度的分析。 Palantir股票的关键指标 自从Palantir(PL……

Pandas入门实践2 -数据处理

为了准备数据进行分析,我们需要执行数据处理。在本节中,我们将学习如何清理和重新格式化数据(例如,重命名列和修复数据类型不匹配)、对其进行重构/整形,以及对其进行丰富(例如,离散化……

一、lua基础知识1

一、lua 的数据类型
–类型 a1; –number print(type(a)) –number b"HelloWorld"; print(type(b)) –string 两种数据类型 ctrue; print(type(c)) –boolean true 或者 false d print; d("HelloWorld"); print(type(d)); –function类型 ……

二、lua语言基础2

1.lua的类型有哪些?答:lua的数据类型有:number,string,nil function,table,thread,userdata(用户自定义的类型),boolean(布尔类型) 2.什么是尾调用,尾调用有什么优点尾调用:在一个函数的最后一步开始调用另……

quick-cocos2dx-luaUI控件讲解

–MyApp部分 require("config") require("cocos.init") require("framework.init") local MyApp class("MyApp", cc.mvc.AppBase) function MyApp:ctor() MyApp.super.ctor(self) end function MyApp:run() cc.FileUti……

quick-cocos2dx lua语言讲解 (动作,定时器,触摸事件,工程的类的讲解)

–MainScene部分
— display.newScene 创建一个场景 — 在quick里面我们的控件、精灵 一般是加载到场景上的 local MainScene class("MainScene", function() return display.newScene("MainScene") end) function MainScene:ctor() –创……

使用quick-cocos2dx-lua 实现的小游戏(包含碰撞检测,触屏发子弹)

–主界面local MainScene class("MainScene", function()return display.newScene("MainScene")end)ON true;function MainScene:ctor()local bg cc.Sprite:create("main_background.png");bg:setScale(2);bg:setPosition(display.cx,display……

cocos2d-js 中scrollview详解

/****
开头的一些废话:
1、多思考,善于思考
2、懂得变通
3、多多查询API首先复制一段 API中的源码:(UIScrollView.js)这段代码可以看出 scrollview
中的容器是一个node,并且他的位置是:代码最后……

cocos2d-js中的回调函数中世界坐标系和节点坐标系的相互转换

世界坐标系和节点坐标系都是OPENGL 坐标系 1、世界坐标系原点就是屏幕的左下角; 2、节点坐标系的原点就是一个节点的左下角; 3、两个坐标系可以通过已经写好的cocosAPI进行想换转换; 4、所有的节点需要转为一个节点上或者是统一的世界坐标系……

通过JavaScript实现漂浮

<html>
<head><meta http-equiv"Content-Type" content"text/html"; charset"gb2312" /><title>漂浮广告</title><style type"text/css">div{position:absolute;}</style>
</head>
&……

Published by

风君子

独自遨游何稽首 揭天掀地慰生平

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注