docker环境下分布式运行jmeter的教程详解
这篇文章主要介绍了docker环境下分布式运行jmeter的教程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
1.构建jmeter的基础镜像
dockerfile文件如下:
123456789101112131415161718192021222324252627282930313233343536# Use Java 8 slim JREFROM openjdk:8-jre-slimMAINTAINER QJP
# JMeter versionARG JMETER_VERSION=5.1.1
# Install few utilitiesRUN apt-get clean && \
apt-get update && \
apt-get -qy
install
\
wget \
telnet \
iputils-ping
\
unzip# Install JMeterRUN
mkdir
/jmeter
\
&&
cd
/jmeter/
\
&& wget https://archive.apache.org/dist/jmeter/binaries/apache-jmeter-$JMETER_VERSION.tgz \
&&
tar
-xzf apache-jmeter-$JMETER_VERSION.tgz \
&&
rm
apache-jmeter-$JMETER_VERSION.tgz
WORKDIR
/jmeter/apache-jmeter-$JMETER_VERSION/bin#从当前文件夹拷贝一份jmeter.properties文件,注意开启:server.rmi.ssl.disable=trueCOPY jmeter.properties .# ADD all the pluginsADD jmeter-plugins/lib
/jmeter/apache-jmeter-$JMETER_VERSION/lib
# ADD the sample testADD sample-test
sample-test
# Set JMeter HomeENV JMETER_HOME
/jmeter/apache-jmeter-$JMETER_VERSION/
# Add JMeter to the PathENV PATH $JMETER_HOME/bin:$PATH
构建镜像
1docker build -t jmbase .
打包上传
12docker tag jmbase dockername/jmbasedocker push dockername/jmbase
2.构建jmeter的master机器镜像
dockerfile文件如下
参考文献:http://www.cncsto.com/article/802
12345678910111213# 使用jmbase基本映像FROM qjpdsg/jmbaseMAINTAINER TestAutomationGuru
# Ports to be exposed from the container for JMeter Slaves/Server# 从JMeter Slaves/Server的容器中要公开的端口EXPOSE 1099 50000
# Application to run on starting the container# 启动容器 运行应用程序ENTRYPOINT $JMETER_HOME/bin/jmeter-server
\
-Dserver.rmi.localport=50000 \
-Dserver_port=1099
构建镜像
1docker build -t jmmaster .
打包上传
12docker tag jmmaster dockername/jmmasterdocker push dockername/jmmaster
3.构建jmeter客户端镜像
dock而file文件如下
1234567# Use jmbase base imageFROM qjpdsg/jmbase
MAINTAINER QJP
# Ports to be exposed from the container for JMeter MasterEXPOSE 60000
构建镜像
1docker build -t jmslave .
打包上传
12docker tag jmmaster dockername/jmslavedocker push dockername/jmslave
4.运行jmeter客服端,得到IP地址:
启动客户端容器:
123docker run -dit --name slave01 jmserver
/bin/bashdocker run -dit --name slave02 jmserver
/bin/bashdocker run -dit --name slave03 jmserver
/bin/bash
得到客户端ip
1docker inspect --format
'{{ .Name }} => {{ .NetworkSettings.IPAddress }}'
$( docker
ps
-a -q)
将ip地址配置到jmeter的master机器的jmeter.properties里面:注意客户端的server_port需要和master的server_port保持一致
如:
设置地址 :
1remote_hosts=172.17.0.2:1099,172.17.0.3:1099
拷贝到jmmaster容器里面:
1docker
cp
./jmeter.properties jmmaster:/jmeter/apache-jmeter-5.1.1/bin/
5.开始分布式测试:
进入到客户端容器里面,运行jmeterserver服务:
12docker
exec
-it slave10
/bin/bashjmeter-server
进入到master容器里面,进行分布式测试:
1jmeter -n -t mywh.jmx -R172.17.0.2,172.17.0.3
到此这篇关于docker环境下分布式运行jmeter的文章就介绍到这了