首页 > 其他分享 >jmeter分布式部署

jmeter分布式部署

时间:2022-12-09 20:14:00浏览次数:43  
标签:测试计划 Jmeter slave 部署 server master jmeter 分布式

一、为什么要进行分布式部署Jmeter

  对于并发量很大的需求,如上万并发量,受到CPU和内存的限制,单机模拟场景是实现不了的,为了让JMeter提供更大的负载能力,须使用它的分布式机制,即多台机器同时产生负载的功能。

  以下参数分析可用于配置负载分布台数的参考:通常,4G内存最多可达到2000左右的并发量。在1.4G Hz~3GHz 的CPU 、1GB 内存的 JMeter 客户端上,可以处理线程 100~300。但是Web Service 例外。XML处理是 CPU 运算密集的,会迅速消耗掉所有的CPU 。一般来说,以XML技术为核心的应用系统,其性能将是普通Web 应用的 10%~25% 。另外,如果所有负载由一台机器产生,网卡和交换机端口都可能产生瓶颈,所以一个JMeter 客户端线程数不应超过 100 。其实我们可以根据这个大概的情况自己调试一下,比如单机上放一个数量级的并发量 500、1000跑起来看看CPU的使用情况,最佳状态是CPU占有率不超过80%。

二、Jmeter分布式执行原理

1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave or Agent)。

2、脚本在master的GUI打开,测试计划仅在master上部署即可,执行时,master GUI会把测试计划发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动自己的GUI。每一台jmeter远程服务器都执行相同的测试计划,jmeter不会在执行期间做负载均衡,每一台服务器都会完整地运行测试计划。

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

三、分布式集群的配置

在部署前请保证各slave机的防火墙处于关闭状态,master与各台slave都可以ping通

1、执行机(slave)配置:

  (1)slave机上需要安装Jmeter和支持当前Jmeter版本的JDK。(有时在运行Jmeter时会提示JDK版本过低)

  (2)添加环境变量:JMETER_HOME路径为bin目录的上一级目录

      

      这样启动jmeter-server服务时,就只会看到Found ApacheJMeter_core.jar

  (3)启动bin目录下的:jmeter-server.bat(Linux下是jmeter-server),启动成功如下图。

      Windows:

        

      Linux:

         

      Linux下启动jmeter-server有时会报错,提示“为知的名称或服务”,如下图:

       

      解决办法:

        1、cat /etc/sysconfig/network查看本机的主机名

        

        2、vi /etc/hosts添加一行本机ip跟主机名映射

        

  (4)上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我改成了1000和1100。 

  (5)多台slave的话,重复1~4步骤就好。

2、调度机(master)配置:

  (1)找到Jmeter的bin目录下的配置文件jmeter.properties,修改如下配置:

      remote_hosts=127.0.0.1:1000,192.168.182.130:1200,192.168.182.129:1100(多台slave之前用 "," 隔开)

  (2)用Jmeter打开测试脚本,为了调试方便,可以为脚本添加“查看结果树”和“聚合报告”。

  (3)打开Jmeter,选择运行→远程启动,可以依次点击远程启动中的slave来执行脚本,对应的slave命令行窗口上会看到启动的信息,全部启动的话可以选择远程全部启动。远程停止同理,也可以远程退出。

      

  每一台slave都执行相同的测试计划,就是在master上设定好的测试计划。

  slave向master回传信息时如果请求执行成功了则不回传具体每个请求的Response信息,当你用查看结果树查看结果时,只能看到取样结果是200,而响应数据里面是空的。

slave控制台信息:

四、自定义端口

  1、在slave机的Jmeter的bin目录下,找到jmeter.properties文件,修改如下两个配置项,比如我这里修改为1200:

      server_port=1200

      server.rmi.localport=1200

  2、启动slave机上的jmeter-server.bat,如下图,端口已经修改为:1200

    

  3、修改master机器的jmeter.properties文件:

    remote_hosts=127.0.0.1:1000,192.168.182.130:1200,192.168.182.129:1100

  4、重启jmeter.bat,如下图,端口已经变了

    

五、其它说明

  1、调度机(master)和执行机(slave)最好分开,由于master需要发送信息给slave并且会接收slave回传回来的测试数据,所以mater自身会有消耗,所以建议单独用一台机器作为mater。

  2、参数文件:如果使用csv进行参数化,那么需要把参数文件在每台slave上拷一份且路径需要设置成一样的,Filename这里设定一下(最好放在bin目录下)。

    

  3、每台机器上安装的Jmeter版本和插件最好都一致,否则会出一些意外的问题。

  4、如果想要master也分担负载,让master自身也执行测试计划,需要把master 的 IP 和 端口也写到配置文件里,在远程启动前,也要把master的 jmeter-server.bat运行,这样master也能和其他slave一起执行测试计划了。

标签:测试计划,Jmeter,slave,部署,server,master,jmeter,分布式
From: https://www.cnblogs.com/wfw001-2018/p/12679817.html

相关文章

  • GFS分布式文件系统
    一、GlusterFS概述1.1GlusterFS简介GlusterFS是一个开源的分布式文件系统。由存储服务器、客户端以及NFS/Samba存储网关(可选,根据需要选择使用)组成。没有元数据服务......
  • 一次不太成功的内网部署视屏会议系统预研
    JitsiMeet背景接到一个任务,想在公司内网搭建一个视频会议系统,用于公司内部或与分公司交流,需要内网部署,最好是开源免费。项目定位查找了如下几个项目:tailchat-meeti......
  • Redis(七)缓存穿透、缓存击穿、缓存雪崩以及分布式锁
    应用问题解决1缓存穿透1.1访问结构正常情况下,服务器接收到浏览器发来的web服务请求,会先去访问redis缓存,如果缓存中存在数据则直接返回,否则会去查询数据库里面的数据,......
  • SpringBoot打war包,放Tomcat部署启动报错
    本人用的Jeecg-boot3.4.4最新版本打war包,按照官方文档war部署方式改了之后,启动tomcat就报如下错09-Dec-202215:08:01.902警告[localhost-startStop-1]org.apache.ca......
  • JMeter+Badboy实现简单压力测试
    JMeter+Badboy实现简单压力测试​​下载需要的工具​​​​下载Badboy步骤:​​​​下载JMeter步骤:​​​​安装Badboy后打开​​​​打开JMeter​​下载需要的工具1.下载Bad......
  • 【分布式技术专题】「架构设计方案」盘点和总结秒杀服务的功能设计及注意事项技术体系
    秒杀应该考虑哪些问题超卖问题分析秒杀的业务场景,最重要的有一点就是超卖问题,假如备货只有100个,但是最终超卖了200,一般来讲秒杀系统的价格都比较低,如果超卖将严重影响公司的......
  • Drone自动部署配置文件
    .drone.yml点击查看代码kind:pipeline#定义对象类型,还有secret和signature两种类型type:docker#定义流水线类型,还有kubernetes、exec、ssh等类型name:build......
  • 二进制部署高可用k8s集群
    一、k8s高可用架构解析etcd是键值数据库用来存储集群信息apiserver是集群的整个控制中心,所有的流量都会经过他ControllerManager控制器,监控整个集群的状态Scheduler调......
  • 论述微服务和分布式
    集中式框架、分布式框架和微服务概要:在系统架构与设计的实践中,从宏观上可以总结为三个阶段:集中式架构:就是把所有的功能、模块都集中到一个项目中,部署在一台服务器上,从而对......
  • 自己动手基于 Redis 实现一个 .NET 的分布式锁类库
    分布式锁的核心其实就是采用一个集中式的服务,然后多个应用节点进行抢占式锁定来进行实现,今天介绍如何采用Redis作为基础服务,实现一个分布式锁的类库,本方案不考虑Redis集......