Jmeter性能测试-分布式压测配置和执行过程

  1. 通过jmeter做分布式集群压测,根据并发需求,配置一个主控机和多个助攻机。比如一台助攻机可以支持1000并发,需求要求5000并发,则需要5台助攻机。每台助攻机能支持的并发数量取决于该机配置如内存、cup和网络。配置高可以支持更多并发。

  2. 主控机和助攻机jemter版本需保持一致。将主控机jemter拷贝到助攻机即可。

  3. 主控机配置。

    复制代码
    # jmeter的bin目录下jmeter.properties
    
    #主控机和助攻机之间不需要加密
    server.rmi.ssl.disable=true
    #配置助攻机的ip和端口
    #端口不固定可随意写
    remote_hosts=192.168.1.120:1068,192.168.1.70:1068
    #在图形界面模式下看到结果
    mode=Standard
  4. 助攻机配置和启动。

    复制代码
    # 将.jmx脚本放到jmeter的bin目录下,然后将jmeter整个包复制到助攻机上。
    
    # jmeter的bin目录下jmeter.properties
    server.rmi.ssl.disable=true
    server_port=10688
    remote_hosts=127.0.0.1
    
    #另外需要关闭助攻机的防火墙
    
    #对bin增加可执行权限,chmod -R 777 bin
    
    #对多台助攻机都需要操作上述步骤配置。
    
    #在bin目录下启动助攻机
    #第一台助攻机
    ./jmeter-server -Djava.rmi.server.hostname=192.168.1.120
    #第二台助攻机
    ./jmeter-server -Djava.rmi.server.hostname=192.168.1.70
  5. 助攻机上RUN查看配置的助攻机。

  6. 选择助攻机执行脚本,查看聚合数效果。

  7. 注意:最初为了调试在http request Defaults中配置的是127.0.0.1.会导致助攻机执行失败。原因是:请求地址写了127.0.0.1:8080------127.0.0.1是 "本地回环地址",只会指向当前机器本身:主控机执行时,127.0.0.1指向主控机自己,所以能成功;远程助攻机执行时,127.0.0.1会指向助攻机自己(但助攻机上并没有部署8080端口的服务),所以会报 "Connection refused(连接被拒绝)"。解决方法:把请求地址里的127.0.0.1改成服务实际部署的机器 IP(比如服务部署在主控机,就填主控机的 IP;部署在其他机器,填对应机器的 IP)。

  8. 无界面执行命令:在主控机的jmeter的bin目录下执行:jmeter -n -t zrlog.jmx -l result.jtl -e -o reports -r,执行完毕后在滨目录生成reports文件夹里有生成的html报告

相关推荐
敖正炀14 小时前
高并发系统的降级预案与容错策略
分布式·架构
敖正炀14 小时前
稳定性监控与告警体系:SLI/SLO/SLA 实践
分布式·架构
敖正炀15 小时前
故障演练与混沌工程:ChaosBlade 到 Litmus
分布式·架构
敖正炀15 小时前
全链路压测与容量规划方法论
分布式·架构
敖正炀15 小时前
限流算法深度与 Guava/Sentinel 源码:从单机令牌桶到分布式滑动窗口的流量防护体系
分布式·架构
山屿落星辰19 小时前
hixl - 让分布式训练“零拷贝“通信
分布式
逍遥德21 小时前
SpringBoot自带TaskScheduler 接口使用详解:(02)微服务多实例模式下,爆发任务重复执行问题
spring boot·分布式·后端·微服务·中间件
Solis程序员1 天前
基于 Outbox 事务表 + Canal 监听+kafka+多级缓存:高并发社交关注系统全链路架构设计
分布式·kafka·linq
phltxy1 天前
Redis集群:分布式高可用存储方案
数据库·redis·分布式
二宝哥1 天前
大数据之安装zookeeper
大数据·分布式·zookeeper