web api性能测试使用wrk

2023-12-10 00:45
文章标签 使用 性能 web 测试 api wrk

本文主要是介绍web api性能测试使用wrk,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

web api性能测试

这边简单的给出shell脚本

注意先安装:wrk和gnuplot

#!/bin/bash# Copyright 2020 Lingfei Kong <colin404@foxmail.com>. All rights reserved.
# Use of this source code is governed by a MIT style
# license that can be found in the LICENSE file.: << EOF
API 性能测试脚本,会自动执行 wrk 命令,采集数据、分析数据并调用 gnuplot 画图使用方式 ( 测试 API 性能):
1. 启动 iam-apiserver(8080端口)
2. 执行测试脚本: ./wrktest.sh脚本会生成 .dat 的数据文件,每列含义为:并发数 QPS 平均响应时间 成功率使用方式 (对比2次测试结果)
1. 性能测试:./wrktest.sh iam-apiserver http://127.0.0.1:8080/healthz
2. 执行命令: ./wrktest.sh diff apiserver.dat http.dat> Note: 需要确保系统安装了 wrk 和 gnuplot 工具
EOFiamroot="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd -P)"
wrkdir="${iamroot}/_output/wrk"
jobname="apiserver"
duration="300s"
threads=$((3 * `grep -c processor /proc/cpuinfo`))source "${iamroot}/scripts/lib/color.sh"# Set wrk options
iam::wrk::setup() {#concurrent="200 500 1000 3000 5000 10000 15000 20000 25000 50000 100000 200000 500000 1000000"concurrent="200 500 1000 3000 5000 10000 15000 20000 25000 50000"cmd="wrk -t${threads} -d${duration} -T30s --latency"
}# Print usage infomation
iam::wrk::usage()
{cat << EOFUsage: $0 [OPTION] [diff] URL
Performance automation test script.URL                    HTTP request url, like: http://127.0.0.1:8080/healthzdiff                   Compare two performance test resultsOPTIONS:-h                     Usage information-n                     Performance test task name, default: apiserver-d                     Directory used to store performance data and gnuplot graphic, default: _output/wrkReprot bugs to <colin404@foxmail.com>.
EOF
}# Convert plot data to useable data
function iam::wrk::convert_plot_data()
{echo "$1" | awk -v datfile="${wrkdir}/${datfile}" ' {if ($0 ~ "Running") {common_time=$2}
if ($0 ~ "connections") {connections=$4common_threads=$1
}
if ($0 ~ "Latency   ") {avg_latency=convertLatency($2)
}
if ($0 ~ "50%") {p50=convertLatency($2)
}
if ($0 ~ "75%") {p75=convertLatency($2)
}
if ($0 ~ "90%") {p90=convertLatency($2)
}
if ($0 ~ "99%") {p99=convertLatency($2)
}
if ($0 ~ "Requests/sec") {qps=$2
}
if ($0 ~ "requests in") {allrequest=$1
}
if ($0 ~ "Socket errors") {err=$4+$6+$8+$10
}
}
END {
rate=sprintf("%.2f", (allrequest-err)*100/allrequest)
print connections,qps,avg_latency,rate >> datfile
}function convertLatency(s) {if (s ~ "us") {sub("us", "", s)return s/1000}
if (s ~ "ms") {sub("ms", "", s)return s
}
if (s ~ "s") {sub("s", "", s)return s * 1000
}
}'
}# Remove existing data file
function iam::wrk::prepare()
{rm -f ${wrkdir}/${datfile}
}# Plot according to gunplot data file
function iam::wrk::plot() {gnuplot <<  EOF
set terminal png enhanced #输出格式为png文件
set ylabel 'QPS'
set xlabel 'Concurrent'
set y2label 'Average Latency (ms)'
set key top left vertical noreverse spacing 1.2 box
set tics out nomirror
set border 3 front
set style line 1 linecolor rgb '#00ff00' linewidth 2 linetype 3 pointtype 2
set style line 2 linecolor rgb '#ff0000' linewidth 1 linetype 3 pointtype 2
set style data linespointsset grid #显示网格
set xtics nomirror rotate #by 90#只需要一个x轴
set mxtics 5
set mytics 5 #可以增加分刻度
set ytics nomirror
set y2ticsset autoscale  y
set autoscale y2set output "${wrkdir}/${qpsttlb}"  #指定数据文件名称
set title "QPS & TTLB\nRunning: ${duration}\nThreads: ${threads}"
plot "${wrkdir}/${datfile}" using 2:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#EE0000" axis x1y1 t "QPS","${wrkdir}/${datfile}" using 3:xticlabels(1) w lp pt 5 ps 1 lc rgbcolor "#0000CD" axis x2y2 t "Avg Latency (ms)"unset y2tics
unset y2label
set ytics nomirror
set yrange[0:100]
set output "${wrkdir}/${successrate}"  #指定数据文件名称
set title "Success Rate\nRunning: ${duration}\nThreads: ${threads}"
plot "${wrkdir}/${datfile}" using 4:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#F62817" t "Success Rate"
EOF
}# Plot diff graphic
function iam::wrk::plot_diff()
{gnuplot <<  EOF
set terminal png enhanced #输出格式为png文件
set xlabel 'Concurrent'
set ylabel 'QPS'
set y2label 'Average Latency (ms)'
set key below left vertical noreverse spacing 1.2 box autotitle columnheader
set tics out nomirror
set border 3 front
set style line 1 linecolor rgb '#00ff00' linewidth 2 linetype 3 pointtype 2
set style line 2 linecolor rgb '#ff0000' linewidth 1 linetype 3 pointtype 2
set style data linespoints#set border 3 lt 3 lw 2   #这会让你的坐标图的border更好看
set grid #显示网格
set xtics nomirror rotate #by 90#只需要一个x轴
set mxtics 5
set mytics 5 #可以增加分刻度
set ytics nomirror
set y2tics#set pointsize 0.4 #点的像素大小
#set datafile separator '\t' #数据文件的字段用\t分开set autoscale  y
set autoscale y2#设置图像的大小 为标准大小的2倍
#set size 2.3,2set output "${wrkdir}/${t1}_${t2}.qps.ttlb.diff.png"  #指定数据文件名称
set title "QPS & TTLB\nRunning: ${duration}\nThreads: ${threads}"
plot "/tmp/plot_diff.dat" using 2:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#EE0000" axis x1y1 t "${t1} QPS","/tmp/plot_diff.dat" using 5:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#EE82EE" axis x1y1 t "${t2} QPS","/tmp/plot_diff.dat" using 3:xticlabels(1) w lp pt 5 ps 1 lc rgbcolor "#0000CD" axis x2y2 t "${t1} Avg Latency (ms)", "/tmp/plot_diff.dat" using 6:xticlabels(1) w lp pt 5 ps 1 lc rgbcolor "#6495ED" axis x2y2 t "${t2} Avg Latency (ms)"unset y2tics
unset y2label
set ytics nomirror
set yrange[0:100]
set output "${wrkdir}/${t1}_${t2}.successrate.diff.png"  #指定数据文件名称
set title "Success Rate\nRunning: ${duration}\nThreads: ${threads}"
plot "/tmp/plot_diff.dat" using 4:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#EE0000" t "${t1} Success Rate","/tmp/plot_diff.dat" using 7:xticlabels(1) w lp pt 7 ps 1 lc rgbcolor "#EE82EE" t "${t2} Success Rate"
EOF
}# Start API performance testing
iam::wrk::start_performance_test() {iam::wrk::preparefor c in ${concurrent}dowrkcmd="${cmd} -c ${c} $1"echo "Running wrk command: ${wrkcmd}"result=`eval ${wrkcmd}`iam::wrk::convert_plot_data "${result}"doneecho -e "\nNow plot according to ${COLOR_MAGENTA}${wrkdir}/${datfile}${COLOR_NORMAL}"iam::wrk::plot &> /dev/nullecho -e "QPS graphic file is: ${COLOR_MAGENTA}${wrkdir}/${qpsttlb}${COLOR_NORMAL}
Success rate graphic file is: ${COLOR_MAGENTA}${wrkdir}/${successrate}${COLOR_NORMAL}"
}while getopts "hd:n:" opt;docase ${opt} ind)wrkdir=${OPTARG};;n)jobname=${OPTARG};;?)iam::wrk::usageexit 0;;esac
doneshift $(($OPTIND-1))mkdir -p ${wrkdir}
case $1 in"diff")if [ "$#" -lt 3 ];theniam::wrk::usageexit 0fit1=$(basename $2|sed 's/.dat//g') # 对比图中红色线条名称t2=$(basename $3|sed 's/.dat//g') # 对比图中粉色线条名称join $2 $3 > /tmp/plot_diff.datiam::wrk::plot_diff `basename $2` `basename $3`exit 0;;*)if [ "$#" -lt 1 ];theniam::wrk::usageexit 0fiurl="$1"qpsttlb="${jobname}_qps_ttlb.png"successrate="${jobname}_successrate.png"datfile="${jobname}.dat"iam::wrk::setupiam::wrk::start_performance_test "${url}";;
esac

直接使用wrk命令

wrk -t144 -c3000 -d30s -T30s --latency 你的url

这篇关于web api性能测试使用wrk的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/475571

相关文章

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)

《JavaWeb项目创建、部署、连接数据库保姆级教程(tomcat)》:本文主要介绍如何在IntelliJIDEA2020.1中创建和部署一个JavaWeb项目,包括创建项目、配置Tomcat服务... 目录简介:一、创建项目二、tomcat部署1、将tomcat解压在一个自己找得到路径2、在idea中添加

Java使用Spire.Doc for Java实现Word自动化插入图片

《Java使用Spire.DocforJava实现Word自动化插入图片》在日常工作中,Word文档是不可或缺的工具,而图片作为信息传达的重要载体,其在文档中的插入与布局显得尤为关键,下面我们就来... 目录1. Spire.Doc for Java库介绍与安装2. 使用特定的环绕方式插入图片3. 在指定位

Springboot3 ResponseEntity 完全使用案例

《Springboot3ResponseEntity完全使用案例》ResponseEntity是SpringBoot中控制HTTP响应的核心工具——它能让你精准定义响应状态码、响应头、响应体,相比... 目录Spring Boot 3 ResponseEntity 完全使用教程前置准备1. 项目基础依赖(M

Java使用Spire.Barcode for Java实现条形码生成与识别

《Java使用Spire.BarcodeforJava实现条形码生成与识别》在现代商业和技术领域,条形码无处不在,本教程将引导您深入了解如何在您的Java项目中利用Spire.Barcodefor... 目录1. Spire.Barcode for Java 简介与环境配置2. 使用 Spire.Barco

Android使用java实现网络连通性检查详解

《Android使用java实现网络连通性检查详解》这篇文章主要为大家详细介绍了Android使用java实现网络连通性检查的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录NetCheck.Java(可直接拷贝)使用示例(Activity/Fragment 内)权限要求

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

C# 预处理指令(# 指令)的具体使用

《C#预处理指令(#指令)的具体使用》本文主要介绍了C#预处理指令(#指令)的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1、预处理指令的本质2、条件编译指令2.1 #define 和 #undef2.2 #if, #el

C#中Trace.Assert的使用小结

《C#中Trace.Assert的使用小结》Trace.Assert是.NET中的运行时断言检查工具,用于验证代码中的关键条件,下面就来详细的介绍一下Trace.Assert的使用,具有一定的参考价值... 目录1、 什么是 Trace.Assert?1.1 最简单的比喻1.2 基本语法2、⚡ 工作原理3