news 2026/5/21 12:48:58

Jmeter 压测-利用Docker分布式压测

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Jmeter 压测-利用Docker分布式压测

Jmeter分布式测试环境中有两个角色:Master 和 Slaves

  1. Master节点:向参与的Slaves节点发送测试脚本,并聚合Agent节点的执行结果。

  2. Slaves节点:接收并执行Master节点发送过来的测试脚本,并将执行结果返回给Master。

为什么要使用docker?

如果要分布式联动每台主机,就要求每台主机都要有Jmeter环境(JDK + JMeter)

如果利用docker就可以通过docker管理 Jmeter环境,简单的拉取镜像,启动容器即可。

进一步讲,利用k8s、云服务可以无限的扩容Jmeter试压机,理论上多少的并发用户都可以模拟。

1、准备工作

JDK:启动 Jmeter 工具需要

$ brew install openjdk@11

Jmeter:编写Jmeter脚本

编写一个简单的脚本。

docker:通过doker创建容器。

  1. $ docker pull runcare/jmeter-master

  2. $ docker pull runcare/jmeter-slave

查看docker镜像

  1. $ docker images

  2. REPOSITORY TAG IMAGE ID CREATED SIZE

  3. runcare/jmeter-master latest e052a8cd8680 3 years ago 326MB

  4. runcare/jmeter-slave latest 05c7ba96d97d 3 years ago 326MB

请记住 jmeter-master 的镜像ID e052a8cd8680,后面会用到。

2、分布式压测使用

启动 slave 节点。

假设有两台主机,可以启动两个slave。​​​​​​​

  1. $ docker run -it -d --name slave01 runcare/jmeter-slave

  2. $ docker run -it -d --name slave02 runcare/jmeter-slave

查看启动的容器​​​​​​​

  1. $ docker ps

  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

  3. b270636a7741 runcare/jmeter-slave "/bin/sh -c 'jmeter-…" 43 seconds ago Up 42 seconds 1099/tcp, 60001/tcp slave01

  4. 2584c7fef5f8 runcare/jmeter-slave "/bin/sh -c 'jmeter-…" 52 seconds ago Up 50 seconds 1099/tcp, 60001/tcp slave02

查看两个slave 的IP 地址​​​​​​​

  1. $ docker inspect -f '{{ .Name }} => {{ .NetworkSettings.IPAddress }}' $(docker ps -q)

  2. /slave01 => 172.17.0.3

  3. /slave02 => 172.17.0.2

  4. /k8s_nginx_nginx-deployment1-fc7586d97-jvjvk_nginx_4379ed7f-b0be-4f9f-a0a9-4a5fd7b45b38_1 =>

  5. /k8s_nginx_nginx-deployment1-fc7586d97-bztbh_nginx_6968e6b1-6689-4f1a-a9ea-04532577841c_1 =>

发送压测脚本到 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

参数说明:​​​​​​​

  1. result=date +"%Y%m%d%H%M%S"`: 指定测试结果的名称,以当前日期时间命名。

  2. /Users/fnngj/zhpro/script : 压测脚本的目录,测试结果也会存放到该目录下。

  3. baidu_script.jmx : 压测脚本的名称,存放于 /Users/fnngj/zhpro/script目录下。

  4. e052a8cd8680 : jmeter-master 的镜像ID。

  5. 172.17.0.2,172.17.0.3 :两台 slave 的IP 地址。

3、测试结果

执行完的目录​​​​​​​

  1. $ pwd

  2. /Users/fnngj/zhpro/script

  3. $ ls

  4. 20230707005328 20230707005328.jtl 20230707005328.log baidu_script.jmx

查看报告

进入20230707005328 目录,点击 index.html 文件,可以看到压测的结果。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/20 12:32:57

谷歌发布40页AI Agent白皮书,简单易懂的智能体认知架构

简单易懂,谷歌发布生成式AI智能体白皮书谷歌终于发布了官方AI Agent白皮书,快来一起研读谷歌发布的AI Agent白皮书,了解智能体一定不要错过谷歌官方出品的AI Agent白皮书,简单易懂的智能体认知架构2025智能体商用元年来袭&#xf…

作者头像 李华
网站建设 2026/5/20 17:55:03

【一招根治】彻底退出Windows 10/11微软账户

作者:Git码农学堂 | 解决时间:2025年12月问题背景 相信很多小伙伴都遇到过这个让人抓狂的问题:一不小心把自己的个人微软账户登录到了公司电脑上,想退出却发现那个邮箱像狗皮膏药一样粘在系统里,怎么都去不掉&#xff…

作者头像 李华
网站建设 2026/5/19 7:06:27

从“证书获取“到“能力建设“:六西格玛培训的价值实现路径

在制造业质量管理的实践中,一个有趣的现象值得深思:两家同行业的包装企业同时派员工参加六西格玛绿带培训,三个月后,A公司的学员成功主导了产线损耗率降低42%的改进项目,而B公司的学员却连基础数据收集工作都未能完成。…

作者头像 李华
网站建设 2026/5/20 22:24:38

基于阶梯式碳机制与电制氢的综合能源系统优化调度:热电联产与氢能效益研究

MATLAB 代码:考虑阶梯式碳机制与电制氢的综合能源系统热电优化 关键词:碳 电制氢 阶梯式碳 综合能源系统 热电优化 参考文档:《考虑阶梯式碳机制与电制氢的综合能源系统热电优化》基本复现 仿真平台:MATLABCPLEX 主要内容:代码主要做的是一个考虑阶梯式碳机制的电热综合能源…

作者头像 李华
网站建设 2026/5/20 12:38:24

可持续测试实践探索

可持续测试的时代背景与意义 在数字化浪潮席卷全球的今天,软件已成为社会运转的核心驱动力,但随之而来的能源消耗、电子废弃物和低效流程也对环境与社会构成了挑战。根据行业数据,全球IT部门的碳排放占总量约2-4%,而低质量软件导…

作者头像 李华
网站建设 2026/5/21 6:23:41

「安卓开发辅助工具按键精灵」xml全分辨率插件jsd插件脚本教程

在处理界面上文字提取的问题,我通常会选择使用jsd插件,感觉用起来挺方便,以往在使用jsd插件的时候就是按照命令提供例子的方法直接使用,这次想自己分析一下每个命令。 jsd插件主要是对节点的处理,我也只分析和节点相关…

作者头像 李华