c多线程并发处理方式_jmeter 并发压测多线程异步处理

大家好,这几天需要搭建一个demo,实现异步推送,线程安全,为了以后项目中,能够推送消息,做的准备,现在分享一下jmeter并发请求,和部分代码

Jmeter教程 简单的压力测试

Jmeter并发数 测试

Jmeter是一个非常好用的压力测试工具。 Jmeter用来做轻量级的压力测试,非常合适,只需要十几分钟,就能把压力测试需要的脚本写好。

阅读目录

  1. 什么是压力测试
  2. 做压力测试的常用工具
  3. 做压力测试的步骤如下:
  4. 本文做压力测试的例子
  5. 第一步: 使用CSV Data Set Config 来参数化
  6. 第二步:添加HTTP Request.
  7. 第三步: 使用Thread Group, 控制模拟多少用户
  8. 第四步: 添加Summary Report 用来查看测试结果
  9. 第五步: 运行一下
  10. 下载源代码

什么是压力测试

顾名思义:压力测试,就是 被测试的系统,在一定的访问压力下,看程序运行是否稳定/服务器运行是否稳定(资源占用情况)

比如: 2000个用户同时到一个购物网站购物,这些用户打开页面的速度是否会变慢,或者网站是否会奔溃

做压力测试的常用工具

做压力测试,一般要使用工具, 人工是没办法做的。 最常用的工具是LoadRunner, 但是LoadRunner毕竟是收费软件,而且使用上也比较复杂。 现在越来越多的人开始使用Jmeter来做压力测试。 免费, 而且使用上非常简单。

做压力测试的步骤如下:

1. 写脚本 或者录制脚本

2. 使用用户自定义参数

3. 场景设计

4. 使用控制器,来控制 模拟多少用户。

5. 使用监听器, 查看测试结果

本文做压力测试的例子

本文举的实例是: 在一台电脑用Jmeter模拟200个用户,同时去使用bing搜索不同的关键字, 查看页面返回的时间是否在正常范围内。

第一步: 使用CSV Data Set Config 来参数化

首先我们把测试需要用到的2个参数放在txt文件中,

新建一个data.txt文件,输入些数据, 一行有两个数据,用逗号分隔。

/*** 执行异步任务 * */@Override@Async("asyncServiceExecutor")public void executeAsync() { logger.info("--------------------------------->start executeAsync"); try{ logger.info("--------------------------------------开始休眠"); Thread.sleep(100); }catch(Exception e){ logger.info("--------------------------------------异步并发报错"); e.printStackTrace(); } logger.info("--------------------------------->end executeAsync");}

启动Jmeter, 先添加一个Thread Group, 然后添加一个CSV Data Set Config (Add -> Config Element -> CSV Data Set Config)

8b1bfcd90cf272c8b8b22128a5e26837.png

第二步:添加HTTP Request.

我们添加http 请求,发送get 到 http://cn.bing.com/search?q=博客园+小坦克

选择Thread Group 右键 (Add ->Sampler -> HTTP Request), 需要填的数据如下:

5d923ca884680be242bda29b59e6d586.png

第三步: 使用Thread Group, 控制模拟多少用户

选中Thread Group

918720f2d42d5b37f68a2b43eb97082d.png

Number of Threads(users): 一个用户占一个线程, 200个线程就是模拟200个用户

Ramp-Up Period(in seconds): 设置线程需要多长时间全部启动。如果线程数为200 ,准备时长为10 ,那么需要1秒钟启动20个线程。也就是每秒钟启动20个线程。

Loop Count: 每个线程发送请求的次数。如果线程数为200 ,循环次数为10 ,那么每个线程发送10次请求。总请求数为200*10=2000 。如果勾选了“永远”,那么所有线程会一直发送请求,直到选择停止运行脚本。

第四步: 添加Summary Report 用来查看测试结果

选中Thread Group 右键(Add -> Listener -> Summary Report)

第五步: 运行一下

到目前为止, 脚本就全写好了, 我们来运行下, 如何看下测试的结果

3a9af687a62d78052d64d50b01277d45.png
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
性能测试中的多线程压测是通过同时模拟多个用户并发访问系统来评估系统的性能表现。多线程压测可以模拟真实的用户行为,通过同时发送多个请求来测试系统在高负载情况下的性能表现。 在多线程压测中,可以使用工具如JMeter来创建多个线程,并设置每个线程的并发访问数量。每个线程代表一个用户,可以设置不同的用户行为和请求参数。通过同时执行多个线程,可以模拟多个用户同时访问系统的情况。 在压测过程中,可以监控系统的响应时间、业务成功率、CPU使用率、内存使用率等指标来评估系统的性能。可以使用工具如InfluxDB和Grafana来实时监控和分析压测结果和服务器性能。这些工具可以提供美观易用的界面,并且可以异步地监控服务器性能,减少对服务器性能的影响。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* [性能测试—接口压测指标分析](https://blog.csdn.net/sanmi8276/article/details/110182515)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Jmeter多线程并发压测结果分析](https://blog.csdn.net/p302519898/article/details/127258136)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值