使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况

1.   安装JMeter及使用

1.1下载JMeter

登录官方网站找到下载链接进行下载:https://jmeter.apache.org/download_jmeter.cgi

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图

1.2配置环境变量

配置JMeter环境变量

新建变量名 JMETER_HOME

值为:JMeter解压目录bin(下载的文件解压目录)

安装Java8+

参考文章:https://blog.csdn.net/weixin_45078706/article/details/115830318

2.新建.Net程序

选择Asp.Net Core Web API

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图1

输入项目名称

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图2

选择框架.Net5.0

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图3

 

 

在Controllers添加包含读/写的API控制器

使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图4

这次分别测试上面4个接口在不同框架下的响应情况

生成解决方案,找到生成目录下的JmeterTest.exe直接运行

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图5

访问http://localhost:5000/swagger/index.html

因为框架默认引用了swagger组件,所以可以直接访问,但页面出现404

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图6

修改Startup.cs代码,注释如下行

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图7

在此生成运行出现swagger页面

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图8

 

3.Jmeter接口测试

打开下载Jmeter解压出来bin目录下的jmeter.bat

出现下面窗口(方便使用切换到中文版本,步骤:Options->Choose Language->Chinese(Simplified))

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图9

3.1新建一个线程组,线程就是模拟用户请求,可设置线程数来控制请求的数量

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图10

参数说明:

  1. 线程数:模拟请求的用户数量
  2. Ramp-Up时间(秒):达到启用指定线程数的时间
  3. 循环次数:线程执行循环的次数,一般在初次测试接口时设置为1,正式压测时设置的永远
  4. Same user on each iteration:待补充..
  5. 延迟创建线程知道需要:待补充..
  6. 调度器:持续时间(秒):程序持续运行时间,启动延时(秒):启动的线程延时多久执行下一组
3.2添加Http请求默认值

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图11

3.3添加HTTP信息头管理器

添加Content-Type:application/json

3.4添加Http请求

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图12

按照需要测试的几种请求接口,这里需要添加四个Http请求

3.5添加响应断言,对请求的接口进行断言,判断是否请求成功

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图13

3.6添加查看结果树,查看详细的接口请求及返回内容

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图14

3.7添加聚合报告查看整体接口请求聚合情况

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图15

3.8进行初步测试确保接口响应没有问题

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图16

3.9修改线程数,启用调度器,再次启动压测请求

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图17

第一次请求出现了大量的:already in use: connect

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图18

搜索找到解决方案修改注册表:

HKEY_LOCAL_MACHINESYSTEMCurrentControlSetServicesTcpipParameters

在Parmeters右键新建DWORD值,命名为MaxUserPort,然后选择十进制并输入数据65534后保存

然后测试发现还是一样的错误,检查参数设置发现Same user on each iteration没有勾选,查询了下资料大概意思是如果选中表示每次请求是同一个用户,不勾选循环的每次是不同的用户

3.10net5.0请求300s结果如下,大概每秒59886.9次请求

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图19

3.11切换至.net6.0

再次进行测试

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图20

请求300s结果如下,大概每秒62232.7次请求,提升了2346,基于net5.0提升了3.9%

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图21

3.12切换至.net7.0

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图22

再次进行测试

 使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况插图23

请求300s结果如下,大概没秒63108次请求,基于net6.0提升876次,提升1.4%,基于net5.0提升3222次,提升5.3%

总结

单纯从接口响应情况来看,net5.0及以上已经有了很大的提升,net6.0,net7.0也都有相应的提升,也为后续的业务处理高并发打下了基础

 

文章来源于互联网:使用JMeter测试.Net5.0,.Net6.0框架下无数据处理的并发情况

THE END
分享
二维码