1.构建jmeter的基础镜像
dockerfile文件如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
# Use Java 8 slim JRE
FROM openjdk:8-jre-slim
MAINTAINER QJP
# JMeter version
ARG JMETER_VERSION=5.1.1
# Install few utilities
RUN apt-get clean && \
apt-get update && \
apt-get -qy install \
wget \
telnet \
iputils- ping \
unzip
# Install JMeter
RUN 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=true
COPY jmeter.properties .
# ADD all the plugins
ADD jmeter-plugins /lib /jmeter/apache-jmeter- $JMETER_VERSION /lib
# ADD the sample test
ADD sample- test sample- test
# Set JMeter Home
ENV JMETER_HOME /jmeter/apache-jmeter- $JMETER_VERSION/
# Add JMeter to the Path
ENV PATH $JMETER_HOME /bin :$PATH
|
构建镜像
1
|
docker build -t jmbase .
|
打包上传
1
2
|
docker tag jmbase dockername /jmbase
docker push dockername /jmbase
|
2.构建jmeter的master机器镜像
dockerfile文件如下
1
2
3
4
5
6
7
8
9
10
11
12
13
|
# 使用jmbase基本映像
FROM qjpdsg /jmbase
MAINTAINER 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
|
构建镜像
1
|
docker build -t jmmaster .
|
打包上传
1
2
|
docker tag jmmaster dockername /jmmaster
docker push dockername /jmmaster
|
3.构建jmeter客户端镜像
dock而file文件如下
1
2
3
4
5
6
7
|
# Use jmbase base image
FROM qjpdsg /jmbase
MAINTAINER QJP
# Ports to be exposed from the container for JMeter Master
EXPOSE 60000
|
构建镜像
1
|
docker build -t jmslave .
|
打包上传
1
2
|
docker tag jmmaster dockername /jmslave
docker push dockername /jmslave
|
4.运行jmeter客服端,得到IP地址:
启动客户端容器:
1
2
3
|
docker run -dit --name slave01 jmserver /bin/bash
docker run -dit --name slave02 jmserver /bin/bash
docker run -dit --name slave03 jmserver /bin/bash
|
得到客户端ip
1
|
docker inspect -- format '{{ .Name }} => {{ .NetworkSettings.IPAddress }}' $( docker ps -a -q)
|
将ip地址配置到jmeter的master机器的jmeter.properties里面:注意客户端的server_port需要和master的server_port保持一致
如:
设置地址 :
1
|
remote_hosts=172.17.0.2:1099,172.17.0.3:1099
|
拷贝到jmmaster容器里面:
1
|
docker cp . /jmeter .properties jmmaster: /jmeter/apache-jmeter-5 .1.1 /bin/
|
5.开始分布式测试:
进入到客户端容器里面,运行jmeterserver服务:
1
2
|
docker exec -it slave10 /bin/bash
jmeter-server
|
进入到master容器里面,进行分布式测试:
1
|
jmeter -n -t mywh.jmx -R172.17.0.2,172.17.0.3
|
到此这篇关于docker环境下分布式运行jmeter的文章就介绍到这了,更多相关docker下分布式运行jmeter内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/qq_40447533/article/details/108983791