备注:【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)

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

出现这个则环境安装成功
备注: 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文件,可界面中查看聚合报告等监听结果

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

5.性能测试报告编写

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

具体看自己存的文档模板

6.出现问题解决方法

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

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

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

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

启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服务即可

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

  1. jmeter安装包双击没反应_windows环境下Jmeter5.2的安装使用

    标签:target   首页   环境变量   百度搜索   bsp   nbsp   htm   targe   oracl 一.安装配置JDK Jmeter5.2依赖JDK1.8 版本,JDK安装 ...

  2. chrome谷歌浏览器执行js脚本步骤

    描述:chrome谷歌浏览器执行js脚本步骤 步骤: F12-顶部Sources-左侧栏箭头Snippets-添加脚本New snippet-RUN

  3. 【jenkins+jmeter+pipeline】使用pipeline方式,分布式执行jmeter脚本,并生成报告

    1.首先准备执行参数 threadsnum---当前并发数(如果是多台slave机运行,最终并发数需要乘以台数) duration---脚本执行持续时间,单位为秒 jmxname--jmx脚本存放路径 ...

  4. 谷歌浏览器32位安装包_谷歌浏览器发布紧急安全更新修复Blink内核中的任意代码执行漏洞...

    上月底谷歌浏览器推送紧急安全更新对浏览器漏洞进行修复,当时谷歌浏览器博客并未公布漏洞的具体细节信息. 蓝点网当时也在文章中称通常这种不公布漏洞的更新,都是比较严重的问题因此只有等多数用户修复后才会公开 ...

  5. zookeeper安装包_构建高可用ZooKeeper集群

    ZooKeeper 是 Apache 的一个顶级项目,为分布式应用提供高效.高可用的分布式协调服务,提供了诸如数据发布/订阅.负载均衡.命名服务.分布式协调/通知和分布式锁等分布式基础服务.由于 Zo ...

  6. 32位mysql安装包_《MySQL 入门教程》第 02 篇 MySQL 安装

    文章来源:<MySQL 入门教程>第 02 篇 MySQL 安装 原文作者:不剪发的Tony老师 来源平台:CSDN 上一篇我们了解了什么是MySQL数据库. 本文介绍如何在 Window ...

  7. docker ubuntu 安装包_史上最全Docker环境安装指南

    一.思考❓❔ 1.什么是Docker? 装应用的容器 开发.测试.运维都偏爱的容器化技术 轻量级 扩展性 一次构建.多次分享.随处运行 2.安装Docker难不难? So easy! 此文看过之后,读 ...

  8. nginx安装包_安装nginx与fastdfs-nginx-module

    首先确保电脑上有相关的安装包, 照我们手上已有的内容来操作 , 现在对这个文件进行解压说 [root@ecs-python01 fastdfs安装]# tar xvfz nginx-1.8.1.tar ...

  9. mysql 5.5.安装包_完美!阿里内部MySQL笔记爆火,肝完不再删库到跑路!(文档+视频贼全!)...

    MySQL凭借着它还不错的性能.还不错的稳定性常年稳居老二宝座,当然最大的优势就是它不要钱,还开源,这让它成为大部分中小型公司,尤其是互联网公司首选的数据库(近年来越来越多的大公司也在尝试将业务转移到 ...

最新文章

  1. debian---nano转VIM
  2. loadrunner安装补丁报错
  3. 每日一皮:是金子无论到哪里、哪怕变个形状都会发光..
  4. 今天做了一个复杂的table
  5. SpringMVC:学习笔记(10)——整合Ckeditor且实现图片上传
  6. 鸟哥的Linux私房菜(服务器)- 第十章、申请合法的主机名
  7. 数论初步——同余与模算术
  8. LINQ Order by 排序
  9. vue路由权限(结合服务端koa2)
  10. mongodb查询的语法(大于,小于,大于或等于,小于或等于等等)
  11. asp生成和导出excel和word数据源码和代码,简单好用(已经测试可以用)
  12. 搭建基于ASP.NET 2.0的DNN 4.X模块开发环境及模块实例(2)
  13. 全面综合的管理平台,让所有网络都有管理员
  14. 每日一题/014/三角函数/和差化积/求证:cos 2+cos 4+cos 6+...+cos 2n=sin ncos(n+1)/sin1
  15. ensp vlan 划分
  16. 免费听歌下载歌曲的几个网站
  17. 电子计算机特征具有什么功能,电子计算机的基本特征有哪些?
  18. linux 不识别 svg,manjaro/archlinux用yaourt -Syu滚动升级后大量图标主题不能用svg图标不能识别...
  19. 软考信息安全工程师+2021-01-30 1.网络信息安全概述+重点
  20. python如何连redis_python连接redis的方法

热门文章

  1. 前端电子表数字字体_爬虫:如何优雅应对字体反爬
  2. java+多线程菜鸟_java多线程
  3. Linux java 生效不了,linux jdk 不生效怎么办
  4. java运算符试题,编程语⾔⾯试题之新版javase基础语法篇之运算符
  5. oracle查询本月第一天_oracle获取本月第一天和最后一天及Oracle trunc()函数的用法...
  6. php计算结果排序,php-按从数组计算出的值对数组进行排序
  7. 添加mysql至服务器_mysql 如何添加服务器
  8. php pdo 绕过,php-带PDO的忘记密码脚本(需要解密)
  9. .net core高并发_高并发下的Node.js与负载均衡
  10. 计算机专业知识多选题证监会,2019年国家公务员考试中国证监会(计算机类)专业科目考试大纲...