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

Master节点:向参与的Slaves节点发送测试脚本,并聚合Agent节点的执行结果。Slaves节点:接收并执行Master节点发送过来的测试脚本,并将执行结果返回给Master。

为什么要使用docker?

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

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

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

1、准备工作

JDK:启动 Jmeter 工具需要

$ brew install openjdk@11

Jmeter:编写Jmeter脚本

编写一个简单的脚本。

图片

docker:通过doker创建容器。

$ docker pull runcare/jmeter-master $ docker pull runcare/jmeter-slave

查看docker镜像

$ docker images 
REPOSITORY              TAG        IMAGE ID       CREATED         SIZEruncare/jmeter-master   latest     e052a8cd8680   3 years ago     326MBruncare/jmeter-slave    latest     05c7ba96d97d   3 years ago     326MB

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

现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】

2、分布式压测使用

启动 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                 NAMESb270636a7741   runcare/jmeter-slave   "/bin/sh -c 'jmeter-…"   43 seconds ago      Up 42 seconds      1099/tcp, 60001/tcp   slave012584c7fef5f8   runcare/jmeter-slave   "/bin/sh -c 'jmeter-…"   52 seconds ago      Up 50 seconds      1099/tcp, 60001/tcp   slave02

查看两个slave 的IP 地址

$ docker inspect -f '{{ .Name }} => {{ .NetworkSettings.IPAddress }}' $(docker ps -q)
/slave01 => 172.17.0.3/slave02 => 172.17.0.2/k8s_nginx_nginx-deployment1-fc7586d97-jvjvk_nginx_4379ed7f-b0be-4f9f-a0a9-4a5fd7b45b38_1 => /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

参数说明:

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 地址。

3、测试结果

执行完的目录

$ pwd/Users/fnngj/zhpro/script

$ ls20230707005328     20230707005328.jtl 20230707005328.log baidu_script.jmx

查看报告

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

图片

下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!

Logo

K8S/Kubernetes社区为您提供最前沿的新闻资讯和知识内容

更多推荐