利用 docker 实现JMeter分布式压测
为什么需要分布式?
在工作中经常需要对一些关键接口做高QPS的压测,JMeter是由Java 语言开发,没创建一个线程(虚拟用户),JVM默认会为每个线程分配1M的堆栈内存空间。受限于单台试压机的配置很难实现太高的并发。所以,通过JMeter实现分布式,可以整合多台主机的硬件资源,实现同时对被测试接口进行压力测试。
Jmeter分布式测试环境中有两个角色:Master 和 Slaves
-
Master节点:向参与的Slaves节点发送测试脚本,并聚合Agent节点的执行结果。
-
Slaves节点:接收并执行Master节点发送过来的测试脚本,并将执行结果返回给Master。
为什么要使用docker?
如果要分布式联动每台主机,就要求每台主机都要有JMeter环境(JDK + JMeter),如果利用docker就可以通过docker管理 JMeter环境,简单的拉取镜像,启动容器即可。进一步讲,利用k8s、云服务可以无限的扩容JMeter试压机,理论上多少的并发用户都可以模拟。
准备工作
- JDK:启动 JMeter 工具需要
$ brew install openjdk@11
- JMeter: 编写JMeter脚本
Index of /dist/jmeter/binaries
编写一个简单的脚本。
- docker: 通过doker创建容器。
-
$ docker pull runcare/jmeter-master
-
$ docker pull runcare/jmeter-slave
- 查看docker镜像
$ docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
runcare/jmeter-master latest e052a8cd8680 3 years ago 326MB
runcare/jmeter-slave latest 05c7ba96d97d 3 years ago 326MB
请记住 jmeter-master 的镜像ID e052a8cd8680,后面会用到。
分布式压测使用
- 启动 slave 节点。
假设有两台主机,可以启动两个slave。
-
$ docker run -it -d --name slave01 runcare/jmeter-slave
-
$ docker run -it -d --name slave02 runcare/jmeter-slave
- 查看启动的容器
$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
b270636a7741 runcare/jmeter-slave "/bin/sh -c 'jmeter-…" 43 seconds ago Up 42 seconds 1099/tcp, 60001/tcp slave01
2584c7fef5f8 runcare/jmeter-slave "/bin/sh -c 'jmeter-…" 52 seconds ago Up 50 seconds 1099/tcp, 60001/tcp slave02
- 发送压测脚本到 slave
$ result=`date +"%Y%m%d%H%M%S"` && docker run --rm -v /Users/fnngj/zhpro/script:/data e052a8cd8680 jmeter -n -t /data/baidu_script.jmx -l /data/$result.jtl -j /data/$result.log -e -o /data/$result -R 172.17.0.2,172.17.0.3
参数说明
result=date +"%Y%m%d%H%M%S"`: 指定测试结果的名称,以当前日期时间命名。
/Users/fnngj/zhpro/script : 压测脚本的目录,测试结果也会存放到该目录下。
baidu_script.jmx : 压测脚本的名称,存放于 /Users/fnngj/zhpro/script目录下。
e052a8cd8680 : jmeter-master 的镜像ID。
172.17.0.2,172.17.0.3 : 两台 slave 的IP 地址。
测试结果
- 执行完的目录
$ pwd
/Users/fnngj/zhpro/script
$ ls
20230707005328 20230707005328.jtl 20230707005328.log baidu_script.jmx
- 查看报告
进入20230707005328 目录,点击 index.html 文件,可以看到压测的结果。
????????????? 【下面是我整理的2023年最全的软件测试工程师学习知识架构体系图】
一、Python编程入门到精通
二、接口自动化项目实战?
三、Web自动化项目实战
四、App自动化项目实战?
五、一线大厂简历
六、测试开发DevOps体系?
七、常用自动化测试工具
八、JMeter性能测试?
九、总结(尾部小惊喜)
生命不息,奋斗不止。每一份努力都不会被辜负,只要坚持不懈,终究会有回报。珍惜时间,追求梦想。不忘初心,砥砺前行。你的未来,由你掌握!
生命短暂,时间宝贵,我们无法预知未来会发生什么,但我们可以掌握当下。珍惜每一天,努力奋斗,让自己变得更加强大和优秀。坚定信念,执着追求,成功终将属于你!
只有不断地挑战自己,才能不断地超越自己。坚持追求梦想,勇敢前行,你就会发现奋斗的过程是如此美好而值得。相信自己,你一定可以做到!?
最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!