压力山大?搭建JMeter分布式压测环境轻松应对!

news/2024/10/17 21:24:59/

目录

引言

windows环境部署

1.安装环境变量

2.配置环境变量

3.修改Jmeter配置文件

4.启动jmeter

5.启动分布式服务

Linux环境部署

1.安装JDK+Jmeter

2.环境优化

4.编写Jmeter脚本

5.启动Jmeter

6.停止Jmeter

7.打包查看测试报告


引言

您想要提高您的应用程序的性能吗?想要确保它在高负载下仍然能够正常工作吗?那么,您一定需要一个可靠的性能测试工具来帮助您完成这个任务。

JMeter是一个广泛使用的性能测试工具,但是如果您的测试需求变得更加复杂和庞大,那么单机运行可能无法满足您的需求。那么有没有一种方法可以提高测试效率呢?

当然有!搭建JMeter分布式压测环境是一个明智的选择。通过增加多台计算机节点,您可以将测试负载分散到不同的计算机上,从而有效地提高测试效率,并且节省大量时间和精力。

在本篇文章中,我们将为您详细介绍如何搭建JMeter分布式压测环境,并分享一些实用的技巧和经验,助您轻松应对压力山大的测试任务。让我们开始吧!

windows环境部署

1.安装环境变量

下载JDK,可以在oracle官网下载

2.配置环境变量

将下载下来的JDk进行安装,添加JAVA_HOME 填写JDK存放路径(根据自己路径进行填写),如C:\Program Files\Java\jdk1.8.0_202

添加JMETER_HOME 填写Jmeter存放路径(根据自己路径进行填写),如D:\办公\3.软件\jmeter5.1+java1.8\apache-jmeter-5.1.1

添加CLASSPATH,将下面内容加在最后

;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;%JMETER_HOME\lib\ext\ApacheJMeter_core.jar;%JMETER_HOME%\lib\jorphan.jar;%JMETER_HOME%\lib\logkit-2.0.jar

添加Path,将下面内容加在最后

%JAVA_HOME%\bin
%JAVA_HOME%\jre\bin
%JMETER_HOME%\bin

3.修改Jmeter配置文件

进入Jmeter配置文件中D:/**/apache-jmeter-5.3/bin/jmeter.properties

server.rmi.ssl.disable=true      # 将false改成true,去掉前面#号

添加发压机(这一步是添加使用Jmeter分布式需要启动的发压机,IP+端口):

remote_hosts=xxx.168.xxxx.2:1099,xxxx.168.xxx.3:1099,xxxx.168.xx.4:1099

4.启动jmeter

Jmeter工具使用请看下面文章:Jmeter压测工具入门篇

5.启动分布式服务

在slave机(发压机)上启动客户端jmeter-server.bat

如下图看到slave已经启动。

slave机启动后,在master选择 运行,远程启动/远程启动所有,就可以分布式的多台slave机一起压测了。

Linux环境部署

1.安装JDK+Jmeter

安装jmeter之前需要先安装jdk,下载jdk(可以使用下面地址进行下载,也可以去官网下载,官网需要登录oracle)

链接: https://pan.baidu.com/s/1Gu5pwMxyxGxN3X94E5NKYg?pwd=ai6j

(内网部署只需要手动把JDK和Jmter包上传到内网解压,其余步骤不变)

解压jdk,这里安装到/usr/local/java/目录(安装路径根据个人喜好,但要和环境变量中的地址匹配)

tar -zxvf jdk-8u181-linux-x64.tar.gz

配置环境变量,修改配置文件vi /etc/profile,文本最后加上以下内容

JAVA_HOME=/usr/local/java/jdk1.8.0_181
CLASSPATH=$JAVA_HOME/lib/
PATH=$PATH:$JAVA_HOME/bin
export PATH JAVA_HOME CLASSPATH

使环境变量生效

source /etc/profile

验证jdk配置成功

java -version

使用命令直接安装Jmeter

wget https://mirrors.bfsu.edu.cn/apache//jmeter/binaries/apache-jmeter-5.4.3.tgz

如果是内网环境,需要手动上传Jmeter安装包,下载最新版Jmeter

解压jmeter,这里安装到/usr/local目录(安装路径根据个人喜好,但要和环境变量中的地址匹配)

tar -zxf apache-jmeter-5.4.3.tgz

建立脚本目录:/root/jmeter/scripts,#脚本上传的地址

建立报告目录:/root/jmeter/report,#报告生成存放目录

配置jmeter环境变量,vi /etc/profile,文本最后加上以下内容

export JMETER_HOME=/usr/local/apache-jmeter-5.4.3
export CLASSPATH=$JMETER_HOME/lib/ext/ApacheJMeter_core.jar:$JMETER_HOME/lib/jorphan.jar:$CLASSPATH
export PATH=$JMETER_HOME/bin:$PATH

使环境变量生效

source /etc/profile

验证jmeter配置成功

jmeter --version

2.环境优化

1.配置jmeter的使用内存,根据实际服务器和测试需求量来修改,最大为服务器内存的一半

vi /usr/local/apache-jmeter-5.4.3/bin/jmeter

2.优化linux内存参数,修改limits.conf文件:

vi /etc/security/limits.conf

最后添加(不同操作系统可能不一样,下面为centos):

*               soft    nofile            102400
*               hard    nofile            102400
*               soft    nproc             65535
*               hard    nproc             65535

重新打开SSH终端,执行如下命令查看是否生效

ulimit -n

3.修改Linux内核参数,修改/etc/sysctl.conf文件:

vi  /etc/sysctl.conf

并添加以下内容:

net.ipv4.tcp_syncookies = 0
fs.file-max = 12553500
fs.nr_open = 12453500
kernel.shmall= 1048576
kernel.shmmax = 1887436
kernel.msgmax = 65536
kernel.sysrq = 0
kernel.pid_max= 65536
net.core.netdev_max_backlog = 2000000
net.core.rmem_default = 699040
net.core.rmem_max = 50331648
net.core.wmem_default = 131072
net.core.wmem_max = 33554432
net.core.somaxconn = 65535
net.ipv4.ip_nonlocal_bind = 1
net.ipv4.tcp_max_orphans = 3276800
net.ipv4.tcp_mem = 1048576 1572864 2097152
net.ipv4.tcp_rmem = 4096 4194304 8388608
net.ipv4.tcp_wmem = 4096 4194304 8388608
net.ipv4.tcp_slow_start_after_idle = 0
net.ipv4.tcp_synack_retries = 1
net.ipv4.tcp_window_scaling = 1
vm.swappiness = 0
#TCP connection recovery
net.ipv4.tcp_max_tw_buckets = 6000000
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_fin_timeout = 30
net.ipv4.route.max_size = 5242880
net.ipv4.ip_forward = 1
#0表示不开启检查时间错,建议设置0
net.ipv4.tcp_timestamps = 0
#开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用
#TCP connection manager
net.ipv4.tcp_max_syn_backlog = 655360
net.ipv4.tcp_syn_retries = 6
net.ipv4.tcp_retries1 = 3
net.ipv4.tcp_retries2 = 6
#TCP keepalive
net.ipv4.ip_local_port_range = 1025 65534
net.ipv4.tcp_keepalive_time = 30
net.ipv4.tcp_keepalive_intvl = 30
net.ipv4.tcp_keepalive_probes = 3

输入下面的命令,让内核参数生效:

sysctl -p

3.修改Jmeter配置文件

进入Jmeter配置文件中D:/**/apache-jmeter-5.3/bin/jmeter.properties

server.rmi.ssl.disable=true      # 将false改成true,去掉前面#号

添加负载机(这一步是添加使用Jmeter分布式需要启动的负载机,IP+端口):

remote_hosts=xxx.168.xxxx.2:1099,xxxx.168.xxx.3:1099,xxxx.168.xx.4:1099

4.编写Jmeter脚本

通过Windows把要压测的Jmeter脚本调试完成,保存为****.jmx文件,上传到Linux服务。

5.启动Jmeter

1)先分别启动slave(所有压测机)上的服务,命令如下(多网卡需要指定ip)

nohup jmeter-server -Djava.rmi.server.hostname=172.168.xxx.2 &  #压测机IP

2)启动master,执行以下命令启动jmeter

jmeter -r -n -t ***.jmx -l test.jtl
参数说明:
-n 非 GUI 模式 -> 在非 GUI 模式下运行 JMeter
-t 测试文件 -> 要运行的 JMeter 测试脚本文件
-l 日志文件 -> 记录结果的文件
-r 代表全部agent启动并参与测试

3)如果要启动指定发压机,执行以下命令

jmeter -n -t ***.jmx -l test.jtl -R xxxx.168.xx,xxxx.168.xx,xxxx.168.xx
参数说明:
-n 非 GUI 模式 -> 在非 GUI 模式下运行 JMeter
-t 测试文件 -> 要运行的 JMeter 测试脚本文件
-l 日志文件 -> 记录结果的文件
-R 指定的agent启动并参与测试

6.停止Jmeter

进入到JMeter 的 bin 目录下,输入 ./shutdown.sh 命令停止脚本

注:如果在分布式压测过程中,想要终止压测,千万不要在Linux上按 ctrl + c 强制终止程序,这样会知道主程序挂了之后,从机未接受到执行,会一直持续运行。当你再次从主机上运行脚本,从机仍然会在上一个脚本的程序中运行,这时需要去杀掉进程。

7.打包查看测试报告

将linux下的report打包成zip,然后导出到windows下查看index.html测试报告

 

写在最后

这篇贴子到这里就结束了,最后,希望看这篇帖子的朋友能够有所收获。

都到这了记得三连支持一下吧。

-------------------------------------------------

完整版文档下载方式:

这些资料,对于从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享。

 

在评论区和我互动交流或者私❤我【软件测试学习】领取即可,拿走不谢。

 


http://www.ppmy.cn/news/107303.html

相关文章

基于长短期神经网络LSTM的飞行轨迹跟踪预测,基于长短期神经网络LSTM的三维路径预测

目录 背影 摘要 LSTM的基本定义 LSTM实现的步骤 基于长短期神经网络LSTM的飞行轨迹跟踪 完整代码: https://download.csdn.net/download/abc991835105/87705046 效果图 结果分析 展望 参考论文 背影 路径追踪预测,对实现自动飞行驾驶拥有重要意义,长短期神经网络是一种改进…

bird 2023 比赛总结

1. 引言 📌 参加这场比赛的时间,应该是还剩一个月不到了,本来没啥想法,因为在忙一些其它的比赛或者是工作和个人上的烦心事,不过在看过了赛题分析后,整体给我感观是一道挺有意思的学习赛,不仅仅…

Java各种工具箱的使用

Java各种工具箱的使用 【一】StrUtil(1)常用的方法(2)hasBlank、hasEmpty方法(3)sub方法(4)去空格 回车操作 与空有关的方法(5)字符串包含关系(6&…

我们和ChatGPT聊了聊BI的未来

ChatGPT是什么? ChatGPT是OpenAI开发的聊天机器人,2022年11月上线,迅速火爆全球,1周突破100万用户,仅用2个月全球突破1亿用户,碾压史上所有应用程序。美国有学生用ChatGPT写论文拿下全班最高分,ChatGPT可以…

设计模式之美-实战二:如何对接口鉴权这样一个功能开发做面向对象分析?

面向对象的三个环节:面向对象分析(OOA)、面向对象设计(OOD)、面向对象编程(OOP)。只知道OOA、OOD、OOP只能说有一个宏观了解,我们更重要的还是要知道“如何做”,也就是&a…

ts reference 报错 ReferenceError: AA is not defined解决方案

我先说重点&#xff01;你看懂了就不用往下看了 ///<reference path"2.ts" /> 像上面这种代码是要编译后才有效果的&#xff0c;所以有些小伙伴发现教程demo也跑不了&#xff0c;跟命名空间啥的没关系&#xff01; 正文 你如果也报我我下面这种错误&#xff…

数据结构与算法07:高效的排序算法

目录 归并排序 快速排序 桶排序 计数排序 基数排序 对比各类排序算法 每日一练&#xff1a;排序链表 在上一篇文章中分析了简单的三种排序算法&#xff1a;冒泡排序、插入排序、选择排序&#xff0c;这三种排序算法的时间复杂度都是O(n^2)&#xff0c;效率不是很高。如果…

消防安全知识答题活动小程序v4.3.0

消防安全知识答题活动小程序v4.3.0 v4.3.0 1&#xff09;实现答题倒计时功能 如果让你给一款答题小程序产品制定一个技术方案&#xff0c;比如实现答题倒计时功能&#xff0c;你会怎么做。 通常&#xff0c;我们对于倒计时的普遍认知是设置一个定时器去实现的&#xff0c;在…