linux使用JMETER进行分布式压力测试

Posted liucx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了linux使用JMETER进行分布式压力测试相关的知识,希望对你有一定的参考价值。

1. 下载jmeter tgz文件   http://jmeter.apache.org/download_jmeter.cgi

 

2. 登录linux服务器,创建jmeter目录,rz上传jmeter

 

3. tar xvf + jmeter tgz文件名

 

4. 添加jmeter环境变量    vi /etc/profile

增加:JMETER=/data/soft/jmeter/apache-jmeter-3.0   //自己的安装路径
CLASSPATH=$CLASSPATH:$JMETER/lib/ext/ApacheJMeter_core.jar:$JMETER/lib/jorphan.jar:$JMETER/lib/logkit-2.0.jar
PATH=$PATH:$JMETER/bin

5. source /etc/profile

6. jmeter -v查看是否设置成功

7. 在jmeter目录创建testplan testresult子目录

8. rz上传jmx脚本到testplan下

脚本使用beanshell:(可以将返回输出到jmeter.log)

prev.setDataEncoding("UTF-8");
String response_data = prev.getResponseDataAsString();
log.error("response_data----------------:"+response_data);

9. 若有host进入/etc/hosts 加入自己的host配置(此过程可以写成shell脚本,每次只需执行脚本即可)

hosts文件的作用相当如DNS,提供IP地址到hostname的对应,Linux系统在向DNS服务器发出域名解析请求之前会查询/etc/hosts文件,如果里面有相应的记录,就会使用hosts里面的记录

//查看当前host hostname (实际与执行脚本使用的host无关,该命令返回的host是系统启动时就一直不变的,若要修改,需要修改以后重启服务器才会永久生效)

vim /etc/sysconfig/network  系统网络配置文件   --需要重启生效,永久性修改。hostname是Linux系统下的一个内核参数,它保存在/proc/sys/kernel/hostname下,但是它的值是Linux启动时从rc.sysinit读取的。而/etc/rc.d/rc.sysinit中HOSTNAME的取值来自与/etc/sysconfig/network下的HOSTNAME

/etc/init.d/network restart  修改网络配置文件后重启网络

 

10. jmeter -n -t testplan/comic.jmx -l testResult/result1.jtl执行脚本并生成聚合报告(在jmeter目录下能够看到jmeter.log或者在testplan目录下,自行寻找,通过日志可以看到出错的地方)

 

-n表示以nogui方式运行测试计划

-t表示测试计划,后面跟测试计划名称

-l表示测试结果,后面跟测试结果文件名称

 

11. sz导出聚合报告,在windows下打开可查看结果

 

分布式配置:

1、同上面步骤,在新的服务器上配置jmeter及环境变量

2、在控制机上修改bin/jmeter.properties,添加从机的IP及端口(使用-r启动所有从机)1099是默认的rmi通信端口

 

# Remote Hosts - comma delimited

remote_hosts=192.168.5.95:1099,192.168.5.103:1099

3、开启执行脚本机器上的server服务,bin/jmeter-server

4、在控制机执行分布式命令

jmeter -n -t testplan/comic.jmx -R 10.15.243.53,10.15.230.78 -l testResult/result1.jtl    指定从机IP

jmeter -n -t testplan/comic.jmx -r -l testResult/result1.jtl  启动所有从机执行脚本

注:若有host同样也需要修改从机的host文件,否则会出现error

 





以上是关于linux使用JMETER进行分布式压力测试的主要内容,如果未能解决你的问题,请参考以下文章

jmeter分布式压测实践及踩坑记录(linux压力机)

Jmeter简单压力测试

分布式压测概念

软件测试之Jmeter压力测试

jmeter服务器压力测试(linux)

jmeter分布式压力测试