jmeter安装包_分布式执行jmeter脚本步骤(非GUI)

备注:【Linux查看服务器是32位还是64位命令】

uname -m

getconf LONG_BIT

1.Linux环境安装jmeter

可参考https://www.cnblogs.com/surewing/p/9271886.html

如需要用到3台客户机,分别在三台机器中安装,以下安装之前需安装jdk环境

1)将jmeter安装包放到服务器

如路径:/app/jmeter

su root 命令:切换到root用户进行如下操作

(新建个jmeter文件夹存放:jmeter包+新建文件夹error+新建文件夹report+新建文件夹script+新建文件jmter.log+自动生成的聚合报告report.jtl)

7dc06f56acd35cb4a593b8dfddfe4ff6.png

2)修改环境变量

编辑环境变量文件:vi /etc/profile

输入并保存:

添加:export JMETER_HOME=/app/jmeter/apache-jmeter-3.3

export CLASSPATH中添加:

;$JMETER_HOME/lib/ext/ApacheJMeter_core.jar:$JMETER_HOME/lib/jorphan.jar:$CLASSPATH

export PATH中添加:

;$JMETER_HOME/bin:$PATH:$HOME/bin

使配置文件生效,必须执行不然修改没生效:

source /etc/profile

(p.s.windows下的环境变量分隔符是分号、linux下的环境分隔符是冒号)

3)检验环境

jmeter -v

4c06c57ddc1f5c520061f3800419ffaa.png
出现这个则环境安装成功

7722487566d5f65752226febec0b02a3.png
备注: jmeter -v命令后,如果出现如下权限问题,需要给jmeter文件夹授权

切换到jmeter目录下,执行如下授权命令:

sudo chmod -R 777 jmeter

2.单台机命令行运行jmeter测试脚本

为什么命令行执行:

1、图形化界面消耗更多资源,CPU和内存

2、图形化界面不支持大型的负载测试和性能测试

3、命令行测试支持持续集成,例如放到Jenkins这样的CI工具上

开始执行...

1、修改配置

(更改jmeter包bin下的文件jmeter.properties)

jmeter.save.saveservice.output_format=xml

注释调该行配置,启用非GUI模式(即该句前加#)

2、运行

进入路径,/app/jmeter执行命令,报告文件report.jtl会在当前运行的路径下生成。

Window系统下命令行执行:

jmeter -n -t D:performancecue入口赋能平台性能测试.jmx -l report.jtl -e -o D:performancereport

Linux系统下命令行执行:

jmeter -n -t /app/jmeter/script/入口赋能平台性能测试脚本.jmx -l report.jtl -e -o /app/jmeter/report

参数解析:

-n:以非GUI形式运行Jmeter

-t:要运行的 JMeter 测试脚本文件

-l:输出结果路径,如果没有该文件就自动创建,可以生成csv或者jtl文件

-e:在脚本运行结束后生成html报告

-o:保存html报告的地址,此文件必须不存在

-h:帮助,打印出有用的信息并退出

-r:远程执行,启动远程服务

-H:代理主机,设置Jmeter使用的代理主机

-P:代理端口,设置Jmeter使用的代理主机的端口号

-J:传递动态参数搭配    duration 持续时间  threadnum 线程数  loopcount 循环次数  ramp  告知Jmeter要在多长时间内建立全部的线程,默认值为0

3.分布式执行jmeter测试脚本

三台机器的jmeter文件夹都授权,不然会遇到上传失败等权限问题:

sudo chmod -R 777 jmeter

可参考:https://www.cnblogs.com/hoby2017/p/9519306.html

选择一个调度机master:100.70.53.44,此机器只负责调度,并汇总输错报告,不执行脚本

选择两台或多台执行机slave:100.70.53.59、100.70.53.39

注意1):这三台机器保证互通(即调度机master和另两台执行机slave互通即可,两台执行机之间可以不通):

登录master机器分别执行命令检测端口:telnet 100.70.53.59 8080

telnet 100.70.53.39 8080

2):所以需要配置端口并保证该端口没有被其他应用占用(上面几个机器中目前只发现8080端口互通),如果被占用,启动jmeter server时会报错

1、slave执行机配置端口

进入jmeter安装路劲/bin,修改jmeter.properties文件

第一个:server_port=8080

第二个:server.rmi.localport=8080

2、slave执行机开启jmeter-server

进入jmeter安装路劲/bin,命令行执行:sh jmeter-server

3、master调度机上指定调度IP地址和端口

进入jmeter安装路劲/bin,修改jmeter.properties文件

修改remote_hosts,回到master机器上,修改jmeter.properties文件中的remote_hosts,将slave机器的ip地址、端口添加上去,多个ip之间用逗号隔开。其中127.0.0.1表示master机器本身,为了独立开master,可以将其去掉,这样就不会在master上执行测试。

如:remote_hosts=100.70.53.59:8080,100.70.53.39:8080

ps:这部好像没配置也没影响,因为执行时的命令会指定路径

4、分布式执行jmete测试脚本

把脚本上传到master机器的scrip文件夹里。

同样进入路径,/app/jmeter执行命令,报告文件report.jtl会在当前运行的路径下生成。

jmeter -n -t /app/jmeter/script/入口赋能平台性能测试脚本.jmx -R

100.70.53.59:8080,100.70.53.39:8080 -l report.jtl -e -o /app/jmeter/report

单机或分布式执行都需注意:需要重新执行脚本时,需先把已生成的报告删除,不然会出现冲突无法执行。

4.查看结果

1、查看生成的报告,report文件夹中的index.html可直接打开,即可查看执行结果

2、Jmeter.log是日志,可查看执行日志

3、Jmeter客户端中的聚合报告等监听器中浏览加载report.jtl文件,可界面中查看聚合报告等监听结果

27a39d9a17bb7f9d01a40115d6ecd5dc.png
在jmeter工具中导入非GUI生成的report.jtl文件

5.性能测试报告编写

参考:https://yq.aliyun.com/articles/35025

具体看自己存的文档模板

6.出现问题解决方法

1)出现如下远程运行后自动关闭,暂不确定什么原因,重启远程服务就好了

094230e9ef3022b18f9573fee51c15db.png

2)非GUI模式生成报告查看结果树中没有返回数据

linux执行jmeter脚本解决响应数据为空 - 疯了的小蜗 - 博客园

3)启动jmeter服务报如下错误,是端口被jmeter占用,之前启动的进程没全部kill

53afde56459e275665d3b6393ea43905.png
启jmeter服务时报如上错误,启动失败

解决方法:

查询端口被谁占用 :参考https://www.cnblogs.com/CEO-H/p/7794306.html

确认是被jmeter占用后,要获取jmeter_pid如下命令:

ps -ef | grep "jmeter" | grep -v grep | awk '{print $2}'

参考https://blog.51cto.com/357712148/2068662

root用户kill调全部进程

再重启jmeter服务即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/534906.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

microbit编程_使用图形化编程实现主控板与手机蓝牙通讯(2019.3.25)

本文转自:DFRobot创客社区原文链接:[Mind]使用图形化编程实现主控板与手机蓝牙通讯-Mind论坛-DF创客社区​mc.dfrobot.com.cn本帖最后由 Forgotten 于 2019-3-25 12:58 编辑做项目时我们经常会遇到蓝牙的问题,例如使用appinventor制作一个app…

山海伏妖录java_山海伏妖录攻略大全 剧情结局加点妖兽大全

山海伏妖录是一款非常经典的ARPG游戏,其中有许多的剧情,结局,妖兽以及加点方案。Remilia为大家带来山海伏妖录攻略大全,各种攻略都能在这里查到,助您畅玩山海伏妖录!山海伏妖录人物介绍配角介绍山海伏妖录结…

spark环境搭建java_Spark MLlib 环境搭建超详细教程

1、系统及环境版本系统:Win7 旗舰版 64位 sp1JDK:1.8.0Spark:2.3.2Hadoop:2.7Scala:2.11.8文章最后,有所有版本的下载链接,不用再去折腾版本之间的问题。2、环境下载2.1 Spark 下载spark2.2 had…

python自动发邮件附件_python自动发送带附件的邮件(163邮箱,亲测可用)

1.设置发送邮件邮箱的SMTP服务 https://www.360kuai.com/pc/927b9f8da3555bb70?cota4&kuai_so1&tj_urlxz&sign360_57c3bbd1&refer_sceneso_1 设置步骤时,记住设置的邮箱的独立密码,在以下脚本中能够用到2. python脚本 import smtplib f…

java 导出bcp文件格式_使用BCP导出导入数据

bcp 实用工具可以在 Microsoft SQL Server 实例和用户指定格式的数据文件间大容量复制数据。 使用 bcp 实用工具可以将大量新行导入 SQL Server 表,或将表数据导出到数据文件。 除非与 queryout 选项一起使用,否则使用该实用工具不需要了解 Transact-SQL…

鱼骨图分析法实际案例_会用“鱼骨图”的项目经理无难题

项目经理在遇到一些瓶颈问题时,如何突破这些难题?答案就是鱼骨图!项目经理,广州深圳PMP培训,PMP认证考试培训机构,圣略PMP培训考试1、鱼骨图分析法介绍鱼骨图的由来及含义鱼骨图是由日本管理大师石川馨先生所发明出来的,故又名石川…

mysql5.6.msi 百度云_如何安装Mysql数据库类型msi(5.6)

首先让大家看下我下载的数据库有多少哈,还不包括我删除的一些数据库。光是8.0.17.0的数据库我就下载了四五个,经常安装数据报错,我一直找不到是啥原因,所以我就把所有的全部给删掉了,然后一遍一遍的安装。现在想想还真…

mysql如何下载msi_2、Windows下MySQL数据库下载与安装详细教程 MSI方式

做者:叁念mysql写在前言:本文篇幅比较长,可是整体分为三大部分:下载部分、安装部分、环境配置与测试部分 ;读者能够自行选择阅读web1、下载部分MySQL数据库下载与安装详细教程sql1.如何下载MySQL?(本文章以5.6版本实际…

python词云乱码_python词云库wordCloud使用方法详解(解决中文乱码)

文章中的例子主要借鉴wordColud的examples,在文章对examples中的例子做了一些改动。 一、wordColud设计中文词云乱码 使用wordColud设计词云的时候可能会产生乱码问题,因为wordColud默认的字体不支持中文,所以我们只需要替换wordColud的默认字…

linux同时安装python2和python3_linux-Centos7安装python3并与python2共存

1.查看是否已经安装Python CentOS 7.2 默认安装了python2.7.5 因为一些命令要用它比如yum 它使用的是python2.7.5。 使用 python -V 命令查看一下是否安装Python 然后使用命令 which python 查看一下Python可执行文件的位置可见执行文件在/usr/bin/ 目录下,切换到该…

opencv获取模板旋转角度_OpenCV入门之获取图像的旋转角度

在我们的日常生活中,所碰到的图像往往都有一定的倾斜。那么,如何用OpenCV来获取图像的旋转角度呢?   我们以下面的图片为例,简单介绍如何用OpenCV来获取图像的旋转角度。可以看到,该图像存在着许多噪声,且…

后台使用orm多还是直接sql_Django应用app创建及ORM

Django应用app创建及ORM一.重要知识点回顾:1. form表单提交数据的注意事项:1. 是form不是from,必须要有method和action (action用来指定你的数据提交到后台哪个地方,method用来指定你提交数据的方式)2. 所有获取用户输入的表单标签要放在form表单里面&am…

求一批整数中出现最多的个位数字_C语言经典100例007-求低n-1位的数

系列文章《C语言经典100例》持续创作中,欢迎大家的关注和支持。喜欢的同学记得点赞、转发、收藏哦~后续C语言经典100例将会以pdf和代码的形式发放到公众号欢迎关注:计算广告生态 即时查收1 题目函数:unsigned fun(unsigned w)功能…

java文件序列化_Java序列化与反序列化,文件操作

参考两篇博客:http://blog.csdn.net/moreevan/article/details/6697777http://blog.csdn.net/moreevan/article/details/6698529针对第二篇博客,看了下面的评论,发现子类输出的书号其实是父类的,书名是自己先添加的成员变量&#…

python自定义模块和三方模块_python基础知识8——模块1——自定义模块和第三方开源模块...

模块的认识模块,用一砣代码实现了某个功能的代码集合。类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合。而对于一个复杂的功能来,可能需要多个函数…

dhcp只能分配与路由器相同网段么_路由器的桥接详解

网上关于路由器无线桥接的教程很多,让你注意那注意这的,都没有说明白。今天,我来试着缕清它们间的关系!1、主路由器这是我主路由器目前的状态,其中IP地址是我在上级光猫路由的可用ip段192.168.1.2~254里选的一个&#…

java orcl自动_Oracle自动生成编号

祝大家新年快乐,有任何问题可与我联系:今天用JAVA向Oracle数据库中插数据时,每次都要去计算ID,觉得好麻烦,于是想到了用数据库自带的ID来做,具体如下:1、首先得创建一序列序列(SEQUENCE)序列是一…

import java.awt.BorderLayout;_Swing-布局管理器之BorderLayout(边界布局)-入门

边界布局管理器(BorderLayout)把容器的的布局分为五个位置:CENTER、EAST、WEST、NORTH、SOUTH。依次对应为:上北(NORTH)、下南(SOUTH)、左西(WEST)、右东(EAST),中(CENTER),如下图所示。特征:l 可以把组件放在这五个位…

java 建造者实际中的用法_java中j建造者模式详解和使用方法

建造者模式(Builder Pattern)使用多个简单的对象一步一步构建成一个复杂的对象。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。一个 Builder 类会一步一步构造最终的对象。该 Builder 类是独立于其他对象的。介绍意图:将一个复杂的…

jsp测试mysql_Jsp登陆与MySQL对接验证

最近在做一个Web项目,账户登陆验证是Web项目中必不可少的环节,所以需要阶段性的记录,帮助自己更好的掌握其中的知识。Jsp登陆涉及到POST方法参数获取,以及MySQL数据库信息的获取。可能因为自己是新手,刚开始写的项目有…