• Jmeter分布式测试笔记


    在性能测试过程中,如果要求并发数较大时(例如1000+),单机配置cpu与内存等无法支持,则需要使用Jmeter的分布式测试方法。

    一、一般什么情况下需要分布式

    1.前辈经验:比如机器i5双核的cpu,8g的内存。压测一个简单的接口,可以支持500+的并发。(但是如果压测方案逻辑复杂,比如在jmeter里面加了很多控制器,监听器,这些都是很耗机器性能,这时候可能连100并发都压不上去)

    2. 压测过程中如果Jmeter未响应,卡住,反应慢,随即启动任务管理器,如果cup和内存特别大时,则说明单机扛不住了,则要使用分布式了

    3. 随着并发的增大,tps不会增长,即出现瓶颈(排除服务器瓶颈及其他),可能是本测试机找不住了,则要分布式

    二、Jmeter分布式测试原理(原理摘抄前辈,感谢)

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

      2、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动GUI,我理解它应该是通过命令行模式执行的。(如果引用到csv等外部的文件,则每台slaver所在的机器都需要相应位置放置该文件。)

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

    三、操作步骤

    写在前面大大的注意啦:

    *****master和slave机中的jmeter版本必须一致(小版本也得一致)。

    ******java的版本也得一致,不能一个java7一个java8(只要大版本一致即可).

    1. 执行机slave配置:

        1.1 安装jmeter,配置环境变量

         1.2在slave机中jmeter-server中

    windows 修改RMI_HOST_DEF=-Djava.rmi.server.hostname=10.120.11.82(slave机的ip)

    运行jmeter-server,Windows运行jmeter-serve.bat  (

    linux: ./jmeter-server -Djava.rmi.server.hostname=10.120.11.82(slave机的ip))

           1.3 上图上标红的IP和端口会在master里配置时用到。IP就是slave机器IP,端口默认是1099,端口也可以自定义,这里我自定义为9999,这个后面说。 

        1.4多台slave的话,重复1~4步骤。  

    2. 启动master

       2.1 找到Jmeter的bin目录下jmeter.properties文件,修改如下配置,IP和Port是slave机的IP以及自定义的端口

            remote_hosts=XXXXXXXXX:9999,XXXXX:9999  (多台slave之前用","隔开)

        2.2 双网卡需要注意:master机需要指定自己机器的ip,要不则会出问题。(非双网卡可以跳过)

     window:

    新增set rmi_host=-Djava.rmi.server.hostname=10.120.11.214(master 的ip)

    修改set ARGS=%DUMP% %HEAP% %NEW% %SURVIVOR% %TENURING% %PERM% %DDRAW% %rmi_host%

    linux:

    新增 rmi_host=“-Djava.rmi.server.hostname=10.120.11.214”(master 的ip)

    修改ARGS="$SERVER $DUMP $HEAP $NEW $SURVIVOR $TENURING $PERM $CLASS_UNLOAD $rmi_host"

    4、开始测试

    4.1master启动jmeter,打开脚本

    设置好并发数等,选择远程全部启动

    4.2slaver控制台信息

    5. 自定义端口

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

          server_port=9999

          server.rmi.localport=9999

    5.2、启动slave机上的jmeter-server.bat端口已经修改为:9999

      

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

          remote_hosts

    5.4、重启jmeter.bat

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

  • 相关阅读:
    父子项目
    生成资源文件时候,可以动态替换为maven属性
    生命周期阶段与插件目标任务绑定
    私服
    仓库
    DotNetBar教程
    SQL基础--> 约束(CONSTRAINT)
    jQuery.Autocomplete实现自动完成功能(详解)
    C# 解析JSON格式数据
    JSON 数据格式解析
  • 原文地址:https://www.cnblogs.com/fennudexiaoniao/p/6913395.html
Copyright © 2020-2023  润新知