热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

服务端性能测试5:JMeter分布式压测

目录1.什么是分布式?2.Jmeter分布式执行原理3.什么情况下采用分布式测试?4.执行机安装启动JDK8并配置环境变量(以Linux为例)5.执行机安装Jmeter3.3(以L

目录

1.什么是分布式?

2.Jmeter分布式执行原理

3.什么情况下采用分布式测试?

4.执行机安装启动JDK8并配置环境变量(以Linux为例)

5.执行机安装Jmeter3.3(以Linux为例)

6.Jmeter3.3分布式压测准备工作

7.非GUI执行分布式压测

8.Jmter压测接口的性能优化

9.HTML压测报告

10.遇到的问题

11.参考文章

最近在学习Jmeter分布式压测实战,看老师讲解的内容,也就是对Controller和Agent进行简单的文件配置,结果等到我实际操作时,几乎每一步都会出现错误,写下这个学习笔记,算是对这两天的一个总结!

在使用Jmeter进行性能测试时,如果并发数比较大(比如项目需要支持1000并发),单台电脑的配置(CPU和内存)可能无法支持,这时可以使用Jmeter提供的分布式测试的功能。

1.什么是分布式?
由多台电脑共同完成同一个任务(请求)部署,我们称这种部署为分布式部署。

2.Jmeter分布式执行原理
一台电脑作为控制机(Controller),其它电脑做为执行机(Agent);
执行时,控制机会把脚本发送到每台执行机上,执行机拿到脚本后就开始执行
执行机执行时不需要启动Jmeter界面,可以理解它是通过命令行模式执行的
执行完成后,执行机会把结果回传给控制机,控制机会收集所有执行机的信息并汇总


3.什么情况下采用分布式测试?
在进行压测的过程中如果出现Jmeter未响应,卡住,反应慢等现象。随即启动任务管理器进行查看,如果cup和内存都特别大。就可以说明现在的负载机出现了瓶颈,需要进行分布式测试。
随着并发数的增长,TPS不再增长,即出现瓶颈(排除服务器瓶颈及其他)。可能是现在的负载机出现了瓶颈,需要进行分布式测试。
在进行压测的过程中出现错误,如Unrecognized Windows Sockets error: 0: recv failed。可能是现在的负载机出现了瓶颈,需要进行分布式测试。
4.执行机安装启动JDK8并配置环境变量(以Linux为例)
参考文章:使用SecureCRT将本地JDK安装包远程上传到Linux并配置环境变量

5.执行机安装Jmeter3.3(以Linux为例)
安装方法与安装jdk类似,可以参考上面的文章进行安装!

6.Jmeter3.3分布式压测准备工作
6.1.执行机的配置

6.1.1.自定义执行机端口号

在执行机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如修改成8899

server_port=8899,表示Controller要远程连接的端口,即remote_hosts=xxx.xxx.xxx.xxx:8899
server.rmi.localport=8899,表示执行机启动时显示的端口,即endpoint:[xxx.xxx.xxx.xxx:8899]
6.1.2.启动jmeter-server

标注1,启动bin目录下的jmeter-server

标注2,执行机的的IP地址和端口号

 

6.2.控制机的配置

打开bin目录下jmeter.properties文件,remote_hosts配置如下,IP和Port是执行机的IP以及端口(端口也可以自定义),多台执行机之前用","隔开,我这里配置了两台执行机,其中一台是Windows系统,另外一台是Linux系统。

 

看网上资料说,Jmeter4.0以上的版本,还要修改一项配置,如下所示,我用的是Jmeter3.3版本,没有配置这一项,对结果也没有影响!

server.rmi.ssl.disable=true
6.3.多网卡配置

我们要在多网卡的服务器上开启RMI服务的话必须指定IP,使他们能够在同一个网段内。 

需要以下几步(假定所有机器都在192.168.0.*网段):

6.3.1.修改agent服务器,指定agent机器的IP

修改jmeter-server文件

# vim jmeter-server

修改RMI_HOST_DEF=-Djava.rmi.server.hostname=192.168.0.109(需要连接的IP)

6.3.2.修改controller服务器,指定controller机器的IP

修改jmeter.bat文件 

新增set rmi_host=-Djava.rmi.server.hostname=192.168.0.108

修改set ARGS=%DUMP% %HEAP% %VERBOSE_GC% %GC_ALGO% %DDRAW% %SYSTEM_PROPS% %rmi_host%

6.4. 打开Jmeter,选择"运行",有"远程启动","远程全部启动"两个选项

 

6.4.1.选择"远程启动"-->192.168.0.109:1099

控制机结果,这里我只启动了192.168.0.109这一台执行机,所以只有一个结果(线程数和循环次数都是1)


执行机控制台信息


6.4.2.选择"远程全部启动"

2台Agent全部启动,所以新增两次执行结果,如下所示:

 

7.非GUI执行分布式压测


-n 非GUI模式   
-t 指定要运行的JMeter测试脚本文件   
                                                       
-l 记录运行结果的文件,每次运行之前,要确保result.jtl不存在,不然会报错
                       
-r jmter.properties文件中指定的所有远程服务器
-e 在脚本运行结束后生成html报告
-o 用于存放html报告的目录(目录要为空,不然会报错) 
8.Jmter压测接口的性能优化
使用非GUI模式
少使用Listener, 如果使用-l参数,它们都可以被删除或禁用。
在加载测试期间不要使用“察看结果树”等监听器,只能在脚本阶段使用它们来调试脚本。
包含控制器在这里没有帮助,因为它将文件中的所有测试元素添加到测试计划中。
不要使用功能模式,使用CSV输出而不是XML。
只保存你需要的数据,尽可能少地使用断言。
如果测试需要大量数据,可以提前准备好测试数据放到数据文件中,以CSV Read方式读取。
用内网压测,减少其他带宽影响压测结果。
如果压测大流量,尽量用多几个节点以非GUI模式向服务器施压。
9.HTML压测报告
下面是1000并发循环10次的html压测报告!

因为是2台Agent执行压测,所以总的请求数=并发数*循环次数*2=20000

9.1.Dashboard

html压测报告里Dashboard的核心指标

9.1.1.Test and Report informations

 

Source file:jtl文件名
Start Time :压测开始时间
End Time :压测结束时间
Filter for display:过滤器
Lable:sampler采样器名称 
9.1.2.APDEX(Application performance Index) & Requests Summary

 

apdex:应用程序性能指标,范围在0~1之间,1表示达到所有用户均满意
T(Toleration threshold):可接受阀值,默认500ms
F(Frustration threshold):失败阀值,默认1500ms

OK:成功率
KO:失败率
 9.1.3.Statistics 统计数据

 

lable:sampler采样器名称
samples:请求总数,并发数*循环次数*执行机个数
KO:失败次数
Error%:失败率

Average:平均响应时间
Min:最小响应时间
Max:最大响应时间
90th pct: 90%的用户响应时间不会超过这个值(关注这个就可以了)
【例如:现在有10个用户的响应时间分别是:2ms,1ms,4,1,5,6,7,6,7,8;那现在把10%的峰值去掉,
这里就是去掉8.所以90th pct是7】

95th pct: 95%的用户响应时间不会超过这个值
99th pct: 99%的用户响应时间不会超过这个值 (存在极端值)
throughtput:Request per Second吞吐量 qps 【几千是低的,一般是上万,机器是16核32G这类的】

received:每秒从服务器接收的数据量
send:每秒发送的数据量
 9.2.Charts报表

html压测报告里Charts的核心指标

9.2.1.Over Time(随着时间的变化)

Response Times Over Time:响应时间变化趋势
Response Time Percentiles Over Time (successful responses):最大,最小,平均,用户响应时间分布
Active Threads Over Time:并发用户数趋势
Bytes Throughput Over Time:每秒接收和请求字节数变化,蓝色表示发送,黄色表示接受
Latencies Over Time:平均响应延时趋势
Connect Time Over Time :连接耗时趋势
9.2.2.Throughput

Hits Per Second (excluding embedded resources):每秒点击次数
Codes Per Second (excluding embedded resources):每秒状态码数量
Transactions Per Second:即TPS,每秒事务数
Response Time Vs Request:响应时间和请求数对比
Latency Vs Request:延迟时间和请求数对比
9.2.3.Response Times

Response Time Percentiles:响应时间百分比(一般看90那里)
Response Time Overview:响应时间概述
Time Vs Threads:活跃线程数和响应时间
Response Time Distribution:响应时间分布图
10.遇到的问题
1.Agent的VM会干扰远程连接

控制机远程启动agent时,报错如下所示:

可以看到,IP地址并不与执行机的IP地址一样

 

 查看资料,发现虚拟机的IP也会出现在远程连接待选列表中,所以连接时会报错,如下所示:

 

解决方法:禁用虚拟机网卡!

2.防火墙未关闭或Controller和Agent不在同一个网段会影响远程连接

 

CentOS6.1关闭防火墙:service iptables stop

解决方法:关闭Agent的防火墙;使Controller和Agent在同一网段。

3.控制机和执行机在同一网段,本地ping不同虚拟机,但虚拟机能ping通本地

关闭了虚拟机的防火墙,但本地还是ping不同虚拟机!

查看网上资料,说是要将虚拟机设成桥接模式,试了一下,本地可以ping通虚拟机了!

如果改成桥接模式,本地还是ping不同虚拟机,建议重启电脑!

因为我在复现这个问题后,将虚拟机改成了桥接模式,但本地还是ping不同虚拟机,把虚拟机的IP地址也改成了静态IP,各种修改,重启了网络,也重启了几遍虚拟机,本地有时能ping通虚拟机,有时ping不通,最后重启了一下电脑,结果搞定了!

CentOS重启网络:service network restart

 

4.控制机上的VMware网卡不可以禁用,否则会提示错误,连不上虚拟机上的Linux,所以控制机和执行机最好分开,不要在一台电脑上,否则会出现很多错误,改完一个问题,会出现另一个问题!

 

11.参考文章
————————————————
版权声明:本文为CSDN博主「小蝌蚪找玛玛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_44679832/article/details/104747330

服务端性能测试5:JMeter分布式压测



推荐阅读
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
  • CSS3 @font-face 字体应用技术解析与实践
    在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 第二十五天接口、多态
    1.java是面向对象的语言。设计模式:接口接口类是从java里衍生出来的,不是python原生支持的主要用于继承里多继承抽象类是python原生支持的主要用于继承里的单继承但是接 ... [详细]
  • 解决Parallels Desktop错误15265的方法
    本文详细介绍了在使用Parallels Desktop时遇到错误15265的多种解决方案,包括检查网络连接、关闭代理服务器和修改主机文件等步骤。 ... [详细]
  • 解决 Windows Server 2016 网络连接问题
    本文详细介绍了如何解决 Windows Server 2016 在使用无线网络 (WLAN) 和有线网络 (以太网) 时遇到的连接问题。包括添加必要的功能和安装正确的驱动程序。 ... [详细]
  • 如何在PHP中准确获取服务器IP地址?
    如何在PHP中准确获取服务器IP地址? ... [详细]
  • 系统转换的三种方法及其具体应用分析
    系统转换是信息技术领域中常见的任务,本文详细探讨了三种主要的系统转换方法及其具体应用场景。这些方法包括:代码迁移、数据迁移和平台迁移。文章通过实例分析了每种方法的优势和局限性,并提供了实际操作中的注意事项和技术要点。例如,代码迁移适用于从VB6获取网页源码,数据迁移在Ubuntu中用于隐藏侧边栏,而平台迁移则涉及Tomcat 6.0的使用和谷歌爬虫的测试。此外,文章还讨论了蓝翰互动PHP面试和5118 SEO工具在系统转换中的应用,为读者提供了全面的技术参考。 ... [详细]
  • V8不仅是一款著名的八缸发动机,广泛应用于道奇Charger、宾利Continental GT和BossHoss摩托车中。自2008年以来,作为Chromium项目的一部分,V8 JavaScript引擎在性能优化和技术创新方面取得了显著进展。该引擎通过先进的编译技术和高效的垃圾回收机制,显著提升了JavaScript的执行效率,为现代Web应用提供了强大的支持。持续的优化和创新使得V8在处理复杂计算和大规模数据时表现更加出色,成为众多开发者和企业的首选。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 第二章:Kafka基础入门与核心概念解析
    本章节主要介绍了Kafka的基本概念及其核心特性。Kafka是一种分布式消息发布和订阅系统,以其卓越的性能和高吞吐量而著称。最初,Kafka被设计用于LinkedIn的活动流和运营数据处理,旨在高效地管理和传输大规模的数据流。这些数据主要包括用户活动记录、系统日志和其他实时信息。通过深入解析Kafka的设计原理和应用场景,读者将能够更好地理解其在现代大数据架构中的重要地位。 ... [详细]
  • Python 实战:异步爬虫(协程技术)与分布式爬虫(多进程应用)深入解析
    本文将深入探讨 Python 异步爬虫和分布式爬虫的技术细节,重点介绍协程技术和多进程应用在爬虫开发中的实际应用。通过对比多进程和协程的工作原理,帮助读者理解两者在性能和资源利用上的差异,从而在实际项目中做出更合适的选择。文章还将结合具体案例,展示如何高效地实现异步和分布式爬虫,以提升数据抓取的效率和稳定性。 ... [详细]
  • 如何尽量处理TIMEWAIT过多?
    如何尽量处理TIMEWAIT过多?编辑内核文件etcsysctl.conf,加入以下内容:net.ipv4.tcp_syncookies1表示开启SYNCookies。当出现SYN ... [详细]
author-avatar
天使不打雨伞_962
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有