zoukankan      html  css  js  c++  java
  • Jmeter—联机负载(分布式)

    转自:https://blog.csdn.net/Rainday666/article/details/102641465

    ·联机负载:
    Jmeter本身的性能问题,导致很多时候我们都需要采用分布式(联机负载)的方式来进行性能测试。

    ·前提条件:
    ·控制机和负载机、负载机和被测服务器之间的网络是通畅。
    ·控制机和负载机上具有相同的jmeter环境。

    ·操作步骤:
    ·第一步:启动负载机上的Jmeter-server.bat。
    PS:默认情况下,server端采用的通信端口是1099,不被占用即可。如果需要修改该端口,则修改jmeter.properties文件中的server_port属性即可。要求端口未被占用。
    如果负载机的server_port被修改,则控制机上添加负载机的时候,host:port中的port也要对应修改。(不需要修改控制机上的server_port属性)。

    ·第二步:在控制机上添加负载机。
    是通过修改控制机的jmeter.properties文件来实现。
    属性:remote_hosts。
    示例:
    remote_hosts=127.0.0.1
    #remote_hosts=localhost:1099,localhost:2010
    remote_hosts=192.168.2.212:8000,192.168.2.100:1099
    PS:表示新增两台负载机,分别是2.212:8000,2.100:1099
    多台负载机之间使用逗号分隔。
    修改之后,需要重启jmeter。

    ·第三步:启动。
    在jmeter中,远程启动有两种方式:
    ·远程启动:选中某一台负载机,运行脚本。
    ·远程全部启动:直接启动所有的负载机运行脚本。

    ·注意事项:
    1、从jmeter4.0开始,分布式负载开始支持基于https的模式(默认)。该模式下,需要额外进行操作:
    ·在控制机上运行bin目录下的脚本:create-rmi-keystore.bat
    则会在bin目录下生成密钥文件:rmi_keystore.jks
    ·将密钥文件rmi_keystore.jks复制到负载机的Jmeter的bin目录即可。

    当然,也可以通过修改控制机与负载机的配置文件jmeter.properties,设置不使用https模式,而是采用http模式。
    #server.rmi.ssl.disable=false
    默认值是false,表示使用ssl模式。
    如果不希望使用,则修改为:
    server.rmi.ssl.disable=true
    PS:控制机和负载机都修改。

    2、联机负载时,脚本的运行环境是负载机。
    这就意味着我们在做联机负载时,要尽可能的保证负载机和控制机的环境的一致性。
    常见的有:
    ·系统环境变量
    ·基础环境,比如说jmeter版本和JDK版本。
    ·第三方文件(参数文件),需要人为的复制分发到负载机。脚本中的访问路径:
    ·如果控制机和负载机的操作系统类型一致,则建议使用绝对路径。
    ·如果控制机和负载机的操作系统类型不一致,则只能使用相对路径。
    ·在本地(控制机上),当前路径是脚本所在路径。
    ·在远程(负载机上),当前路径是Jmeter的bin目录所在路径。

    3、远程全部启动时,如果负载机的数量大于等于两台。脚本是分别、独立、同步在不同的负载机上运行的。
    这就意味着,对于服务器而言,承受的压力是:
    线程组设计的压力×负载机的数量。

    4、如果需要获取错误响应,则需要修改模式为:standard。
    默认情况下,负载机是只会将一些特定的数据反馈给控制机的,通常不会包含服务器的响应。
    则需要修改以下配置(包括控制机和负载机)。
    jmeter.save.saveservice.output_format=xml
    jmeter.save.saveservice.response_data.on_error=true

    #Remote batching support
    mode=Standard

  • 相关阅读:
    矩阵相关计算-基础
    列表-元祖-字典
    Python制作NTF传递函数工况文件和后处理文件
    C++栈和堆的生长方向
    malloc/free与new/delete的区别
    C++中4个类型转换相关的关键字/特点/应用场合
    Python 拾遗
    Python 常用库
    Python 视频转字符动画
    Python 命令行(CLI)基础库
  • 原文地址:https://www.cnblogs.com/nnniki/p/12829698.html
Copyright © 2011-2022 走看看