性能测试工具 jmeter 分布式压力测试实操

本文在Non-GUI Mode下进行,准备好三台有jdk环境,linux操作系统,同一局域网测试机器,运行两台slave,一台master机器,进行分布式测试。

slave-1/slave-2/master配置好jmeter环境(以下操作在jdk版本1.8环境下进行的)

1.下载jmeter3.2

wget https://archive.apache.org/dist/jmeter/binaries/apache-jmeter-3.2.tgz

2.解压

tar xvf apache-jmeter-3.2.tgz

3.添加环境变量

vim  /ect/profile

最后一行添加代码:

JMETER=/root/apache-jmeter-3.2
CLASSPATH=$CLASSPATH:$JMETER/lib/ext/ApacheJMeter_core.jar:$JMETER/lib/jorphan.jar:$JMETER/lib/logkit-2.0.jar
PATH=$PATH:$JMETER/bin

运行以下命令修改立即生效:

source /etc/profile

查看版本是否配置成功:

jmeter -v 

4.准备好自己的测试脚本jmx文件放在目录/apache-jmeter-3.2/test下

slave-1 / slave-2 启动jmeter-server

5.运行jmeter-server

进到目录/apache-jmeter-3.2/bin:

vim jmeter-server

添加以下代码:(****为每台server自己的ip):

RMI_HOST_DEF=-Djava.rmi.server.hostname=****
  • 开启jmeter-server:

    ./jmeter-server
  • 运行成功的话会在控制台显示:

    Created remote object: UnicastServerRef [liveRef: [endpoint:[***](local),objID:[***, ***]]]

master机器运行测试脚本

6.修改配置文件jmeter.properties

进入目录/apache-jmeter-3.2/bin:

vim jmeter.properties

大概1038行,添加以下代码:

jmeterengine.nongui.port=0

7.运行脚本,开始测试

测试脚本test.jmx,在目录/apache-jmeter-3.2/test下,新建文件夹report,用来保存结果:

mkdir report

运行以下命令(***为slave测试机器的ip,以逗号,间隔):

jmeter -n -t ws_test.jmx -R  ***,*** -l test.jtl -e -o /apache-jmeter-3.2/test/report/
  • 提示以下消息则表示成功开始测试:

    Creating summariser <summary>
    Created the tree successfully using test.jmx
    Configuring remote engine: ***
    Configuring remote engine: ***
    Starting remote engines
    Starting the test @ Sun Mar 04 11:23:31 CST 2018 (1520133811112)
    Remote engines have been started
  • 此时slave机器控制台会提示:

    Starting the test on host *** @ Sun Mar 04 11:23:32 CST 2018 (1520133812700)
  • 测试脚本运行结束master控制台会显示结果:

     
  • slave机器控制台会提示:

    Finished the test on host *** @ Sun Mar 04 11:25:53 CST 2018 (1520133953286)

    至此测试已经完成。

8.查看测试结果报告

master 机器上运行:

python -m SimpleHTTPServer 8000

报告查看网址(***为该机器ip):http://***:8000/report/index.html

9.遇到的坑

  • 在slave开启jmeter-server时,直接运行./jmeter-server,会提示错误

    Server failed to start: java.rmi.RemoteException: Cannot start. ***  is a loopback address.
    An error occurred: Cannot start. *** is a loopback address.

    貌似是因为没有指定主机导致的,所以在jmeter-server中指定RMI_HOST_DEF写入hostname搞定了问题:

    vim jmeter-server

    添加以下代码:(***为每台server自己的ip):

    RMI_HOST_DEF=-Djava.rmi.server.hostname=***
  • 在master跑测试脚本时,会一直提示如下信息,导致测试一直跑不起来:

    Waiting for possible shutdown message on port 4445 

    解决方法:
    进入目录/apache-jmeter-3.2/bin:

    vim jmeter.properties

    大概1038行,添加以下代码:

    jmeterengine.nongui.port=0

    这个是用于监听shutdown message的,如果不需要,可以直接设置为0即可。

  • 每台机器要在同一局域网下,最好操作系统保持一致(此次测试在linux下实现),不然运行master测试脚本有可能会提示拒绝连接的错误。

性能测试工具 jmeter 分布式压力测试实操的更多相关文章

  1. jmeter分布式压力测试实践+登录为例

    1.一张分布式压力的图解,如下 准备: 1.两台slave 2.一个master 3.待测目标地址 http://XXX 准备环境:linux环境,master如果可以最好有可视化电脑界面,便于jmx ...

  2. linux上实现jmeter分布式压力测试(转)

    摘要:最近根据公司工作的需求,学习了一些压力测试的知识,目前,公司使用的是jmeter进行压力测试.下面就记录下近期的学习.我想将这次的博文分成三个部分:1.开始测试前的准备(测试环境的搭建)2.在一 ...

  3. 【转】Jmeter分布式压力测试

    安装 下载地址:http://jmeter.apache.org/download_jmeter.cgi 安装前提(因为jmeter依赖于Java所以必须先配置好java) 下载后解压: tar -x ...

  4. Jmeter 分布式压力测试

      JMeter中进行分布式测试 作为一个纯 JAVA 的GUI应用,JMeter对于CPU和内存的消耗还是很惊人的,所以当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心, ...

  5. Jmeter分布式压力测试

    有时候,一台机器无法支持很多个虚拟用户并发,这时就会使用分布式测试来实现这个功能,jmeter是有提供这个功能的.要实现分布式测试,得在主从(agent和controler)机器的jmeter安装目录 ...

  6. jmeter分布式压力测试配置操作

    前提准备条件:1.主控机一台为master,ip地址:10.8.88.1772.负载机一台为slave, ip地址:10.8.88.1193.主控机和负载机都安装一样的JDK环境和jmeter版本.5 ...

  7. Jmeter性能测试-分布式压力测试

    作为一个测试行业的菜鸟,由于投身于一个小公司,包揽所有的测试.刚开始的功能测试到接口测试,稳定性测试,兼容性测试等,一般由于是小项目所以对于性能有所忽略,也没怎么涉及,公司接了个大项目,后期对于性能上 ...

  8. .net分布式压力测试工具(Beetle.DT)

    肯定有人会问为什么会写这样一个开源工具?和现有的有什么差别?不过对于一个程序员来说写东西还真不需要理由的:),主要原因是工作有点闲(开玩笑),不过说实话一个程员怎可能会停止写代码呢(作为一个奔4的程序 ...

  9. 性能测试工具JMeter 基础(六)—— 测试元件: 线程组

    线程组的定义: 线程组是测试计划执行的入口,所有的逻辑控制器和取样器都必须在线程组下,其他的元件根据位置的不同作用域是不同的. 线程组是每个线程都是独立运行测试脚本,一个线程组就等于一个用户,通过多个 ...

随机推荐

  1. bugkuCTFWEB部分WP

    前言 之前做的今天整理下 这个有点乱不建议大家参考我的wp 这个主要是自己看的.部分的我做的时候打不开就没写. 练手地址:https://ctf.bugku.com 矛盾 矛盾考察的是PHP弱类型首先 ...

  2. C++中new和malloc区别

    面试中new和malloc区别会被经常问到,审视了自己,发现不知道该怎么表达 整理一下: 1.从属性 new/delete是C++关键字,需要编译器支持: malloc/free是库函数,需要头文件支 ...

  3. 苹果电脑中怎么快速卸载Flash Player和浏览器扩展应用插件

    Adobe Flash Player是一款轻量级浏览器插件,帮助你在网页浏览过程中享受更广泛的多媒体体验.是一种拓展,与Java一样,成为安全和隐私问题的重要来源.这些都需要手动删除的Flash是令人 ...

  4. 使用Folx下载任务完成后,怎么自动完成关闭

    下载工具的优点是可以通过多线程的方式,提高文件的下载速度,减少用户的下载时间.但另一方面来说,下载工具为了达到高速下载,也会占据较多的带宽资源,甚至会拖慢电脑的运行. 因此,很多用户会利用电脑的空闲时 ...

  5. 红外遥控接收发射原理及ESP8266实现

    红外遥控是利用近红外光进行数据传输的一种控制方式.近红外光波长0.76um~1.5um ,红外遥控收发器件波长一般为 0.8um~0.94um ,具有传输效率高,成本低,电路实现简单,抗干扰强等特点, ...

  6. 蓝桥杯——压缩变换(2016JavaB组第9题)

    压缩变换(16JavaB9) 小明最近在研究压缩算法. 他知道,压缩的时候如果能够使得数值很小,就能通过熵编码得到较高的压缩比. 然而,要使数值很小是一个挑战. 最近,小明需要压缩一些正整数的序列,这 ...

  7. Java复数的定义与描述

    1 //4.复数的定义与描述 2 package test; 3 4 import java.util.Scanner; 5 6 public class complex {//复数类 7 doubl ...

  8. 【mq读书笔记】mq读写分离机制

    mq根据brokerName查找Broker地址的过程 mq根据MessageQueue查找Broker地址的唯一依据是brokerName,同一组Broker(M-S)他们的bokerName相同但 ...

  9. 基于 RabbitMQ-EasyNetQ 实现.NET与Go的消息调度交互

    基于 RabbitMQ 实现跨语言的消息调度 微服务的盛行,使我们由原来的单机"巨服务"的项目拆分成了不同的业务相对独立的模块,以及与业务不相关的中间件模块.这样我们免不了在公司不 ...

  10. 冲刺随笔——Day_Six

    这个作业属于哪个课程 软件工程 (福州大学至诚学院 - 计算机工程系) 这个作业要求在哪里 团队作业第五次--Alpha冲刺 这个作业的目标 团队进行Alpha冲刺 作业正文 正文 其他参考文献 无 ...