困扰很多人的分布式性能测试,原来如此简单!

2024-03-10 05:28

本文主要是介绍困扰很多人的分布式性能测试,原来如此简单!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

我经常会遇到一些跟我聊性能测试工具Jmeter不好用,我问为什么不好用,他说压力稍微大一些就上不去报错了。一看报错信息就是地址被占用了。这就是典型的分布式的需求了。如果做性能测试,这个基本的问题都不会解决的话,那么表示性能测试你还没有入门哦!

我经常会遇到一些学生跟我聊性能测试工具Jmeter不好用,我问为什么不好用,他说压力稍微大一些就上不去报错了。一看报错信息就是地址被占用了。

图片

这就是典型的分布式的需求了。如果做性能测试,这个基本的问题都不会解决的话,那么表示性能测试你还没有入门哦!

性能测试为什么需要分布式?

我们做性能测试的工具Jmeter是安装在电脑或者服务器机器上的,不管是windows的电脑还是Linux系统机器,能够被使用的端口都是有限的,理论上的最大值 65535个,但是实际上都还到不了这个值:

  • 因为windows机器作为图像界面系统,就是为 普通用户使用, 一般用不了 很多端口。

  • linux机器:默认的时候理论上可用的端口大概有3w个左右

  • windows机器:默认的时候理论上只有 大于 1w+多个端口

然而,我们接口发送请求所用的协议是HTTP协议,这个协议特点:

  • 默认是一个长连接【connection= keep-alive】。所以,每一个请求占用一个端口,而这个请求因为是长连接还会保持一段时间,不会立马释放这个端口。这就导致机器上的端口快速被消耗完。

  • http协议是一个同步协议,一个请求发送完,一定要等收到响应了才发送下一个请求,所以如果服务器的性能越好,服务器能短时间内处理大量的请求,Jmeter客户端的端口就更快被消耗完,所以服务器性能越好,Jmeter能产生的并发用户数反而越少。

而实际项目有可能接口性能比较好,能超过2000并发用户数,这就会超过1个Jmeter客户端能产生的并发用户数。这个时候,我们就需要通过增加Jmeter的机器来产生更多的并发用户数。这就是分布式。

分布式的原理

按照上面讲的分析,分布式就是为了增加客户机对服务器执行并发请求,突破单个机器的瓶颈。分布式的配置图如下:

图片

1、一台主控制/调度机【Controller/Master】, 多台机器为执行机/助攻机【Slave/Agent】

2、执行的时候master会把脚本发送到助攻机上,每个助攻机拿到脚本后开始在还行

  • 注意每台助攻机上都需要有Jmeter安装环境;

  • Jmeter不需要启动gui界面,直接用cli命令行执行;

  • 助攻机会用Linux/windows/macOS都可以,一般推荐用同种机器。

3、执行完成后,slave会把结果传回给master,master会收集所有的salve信息会汇总显示。

所以,性能测试脚本只需要管理者在主控制机上维护和修改变更就可以。假设管理者把线程数变了。每个助攻机的执行者就都按照新的线程数来产生并发用户数。

分布式环境搭建

前提条件准备:
  • 主机和助攻机器jmeter的版本要相同,jdk要主版本要一致。

  • Jmeter的csv的脚本相对路径的启始点一致。

  • Jmeter的插件要一致 。

  • 所有的主控机和助攻机都必须用有线连接网络,同一局域网。

助攻机的配置:

修改Jmeter的配置文件:jmeter.properties

  • 修改 server_port 端口 :默认是1099, 可以不改,也可以修改为自己定义的;

  • 修改 server.rmi.port 端口 :可以不改,如果改就改成和上面相同

  • 去掉认证 server.rmi.ssl.disable=true 不使用加密认证传输数据

完成这些修改,并保存文件,助攻机器的配置完成。保证每台助攻机器都同样的配置。

主控机的配置:

修改配置文件:jmeter.properties

  • remote_hosts=助攻机器ip:端口 ,如果有多个助攻机器信息之间用逗号分开 ;

  • 去掉认证:server.rmi.ssl.disable=true

确认模式:mode=Standard 这个属性,主控和助攻机器之间,使用通用的标准的数据交换方式。

注意:修改属性配置文件,一定要保存文件,然后重启jmeter才生效
启动助攻机,启动命令:

windows:jmeter-server.bat -Djava.rmi.server.hostname=机器ip

**linux: **./jmeter-server -Djava.rmi.server.hostname=192.168.88.134

配置完成后,可以在jmeter图形界面中,看到助攻机器传回来的数据。

图片

点击上图的启动远程可以启动主动机开始跑脚本。可以启动部分,也可以同时启动所有助攻机跑脚本。如此就完美解决了一台客户机运行报错压力上不去的问题。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取 

 

这篇关于困扰很多人的分布式性能测试,原来如此简单!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/793189

相关文章

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Jenkins分布式集群配置方式

《Jenkins分布式集群配置方式》:本文主要介绍Jenkins分布式集群配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1.安装jenkins2.配置集群总结Jenkins是一个开源项目,它提供了一个容易使用的持续集成系统,并且提供了大量的plugin满

使用Python进行GRPC和Dubbo协议的高级测试

《使用Python进行GRPC和Dubbo协议的高级测试》GRPC(GoogleRemoteProcedureCall)是一种高性能、开源的远程过程调用(RPC)框架,Dubbo是一种高性能的分布式服... 目录01 GRPC测试安装gRPC编写.proto文件实现服务02 Dubbo测试1. 安装Dubb

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

JVisualVM之Java性能监控与调优利器详解

《JVisualVM之Java性能监控与调优利器详解》本文将详细介绍JVisualVM的使用方法,并结合实际案例展示如何利用它进行性能调优,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录1. JVisualVM简介2. JVisualVM的安装与启动2.1 启动JVisualVM2

Java使用MethodHandle来替代反射,提高性能问题

《Java使用MethodHandle来替代反射,提高性能问题》:本文主要介绍Java使用MethodHandle来替代反射,提高性能问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录一、认识MethodHandle1、简介2、使用方式3、与反射的区别二、示例1、基本使用2、(重要)

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、