首页 > 其他分享 >jmeter分布式测试安装部署步骤

jmeter分布式测试安装部署步骤

时间:2023-04-04 19:00:35浏览次数:40  
标签:bin 查看 jdk 步骤 1099 linux jmeter 分布式

一、下载linux版本的jdk ----注:下载的jdk和jmeter要与window的jdk和jmeter一致 下载地址:https://www.oracle.com/java/technologies/downloads/#java11

二、在虚拟机中使用su root 超级管理员的账号进行操作,在/usr/local下创建jdk文件夹

 

在linux中输入命令:cd /usr/local   ----命令:mkdir jdk

三、上传jdk1.8包上传到指定目录jdk中,将其解压到jdk目录下

在linux中输入命令:tar -zxvf jdk-8u261-linux-x64.tar.gz

四、配置环境变量——在linux中输入命令:vim /etc/profile

 

在最后添加如下(注意:系统之前如果有环境变量则不要动他们,在原有的基础添加jdk环境变量即可):

 

#set java enviroment

 

export JAVA_HOME=/usr/local/jdk/jdk1.8.0_144        ------linux下安装jdk的位置

 

export JRE_HOME=${JAVA_HOME}/jre

 

export CLASS_PATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib

 

export PATH=${JAVA_HOME}/bin:$PATH

五、执行profile文件。 输入命令:source /etc/profile

六、查看jdk安装情况。输入命令:java -version    出现图下则表示安装成功

 

七、安装jmeter,将windows下的包发送到linux中并进行解压,进入安装包目录执行解压。输入命令:tar zxvf apache-jmeter-5.2.1.tgz

八、执行命令vi /etc/profile,在文件底部增加如下内容,并保存。输入命令按i,保存退出命令为:wq

 

JMETER=/home/root2/jmeter/apache-jmeter-5.2.1   ------linux下jmeter存放的位置

 

CLASSPATH=$JMETER/lib/ext/ApacheJMeter_core.jar:$JMETER/lib/jorphan.jar:$JMETER/lib/logkit-2.0.jar:$CLASSPATH

 

PATH=$PATH:$JMETER/bin

 

export JMETER PATH

九、执行命令source /etc/profile ,生效文件修改。

十、执行命令jmeter -v,显示jmeter版本信息则表示安装成功

 

 

 

 

 

 

 

十一、分布式部署操作步骤:

1、控制机和执行机的配置

1) 控制机设置:

打开在windows下的jmeter中的bin-jmeter.properties文件,搜索host,编辑remote_hosts=localhost:1099,localhost:2010 (该地址为linux下执行机的地址,具体地址信息可在linux下输入ifconfig可查看地址)

如下:

# remote_hosts=127.0.0.1

remote_hosts=192.168.202.130:1099 (有多少台执行机,则添加多少台执行机的ip,端口都一致,多台以逗号进行隔开)

 

关闭ssl设置--不关闭会连不上执行机:

打开在windows下的jmeter中的bin-jmeter.properties文件,搜索以下,将false改为true,改为后如下:

#Set this if you don't want to use SSL for RMI

server.rmi.ssl.disable=true

 

2)执行机设置

打开在linux下的jmeter中的bin-jmeter.properties文件,搜索host,编辑remote_hosts=localhost:1099,localhost:2010 (该地址为linux下执行机的地址,具体地址信息可在linux下输入ifconfig可查看地址)

如下:

# remote_hosts=127.0.0.1

remote_hosts=192.168.202.130:1099

 

关闭ssl设置--不关闭会连不上执行机:

打开在linux下的jmeter中的bin-jmeter.properties文件,搜索以下,将false改为true,改为后如下:

#Set this if you don't want to use SSL for RMI

server.rmi.ssl.disable=true

 

2、配置完后,操作流程

1) 启动运行:在;linux下进入bin目录下运行: ./jmeter-server -Djava.rmi.server.hostname=192.168.202.130:1099

2) 如运行因为权限不够提示以下报错:

bash: ./jmeter-server: Permission denied

 3)修改最高权限

 chmod 777 jmeter-server

4)再次运行: ./jmeter-server -Djava.rmi.server.hostname=192.168.202.130

5)出现下图则运行成功:

 

3、在window上进行远程启动执行机报错场景的解决方案

解决方案:

1)查看slave上的ip与master配置文件中的ip是否一致;

如果不一致,查看slave机器上是否有虚拟网卡,将网卡关闭,在此启动Jmeter-server.bat,查看是否正确

 

2)查看防火墙是否关闭

注:centos7上关闭防火墙:  firewall-cmd --state   //查看防火墙状态

                           systemctl stop firewalld.service //关闭防火墙

 

问题1:当设置csv文件路径时,如果路径不对,无响应

解决方法:将csv文件以“相对路径”命名,即将csv文件直接放入bin目录下,在Jmeter路径中直接写入文件名

 

问题2:(Linux)默认端看1099被占用,如何关闭某个被占用端口的方法

1)netstat -ntlp //查看当前所以tcp端口

nestat -ntulp |grep 1109 //查看所有1109端口使用情况

2)lsof -i:1109 //查看占用1109端口的程序pid

3)kill -9 1109 //kill掉该进程

 

(windows)上关闭已被占用的端口  http://www.jb51.net/os/windows/203315.html

如1099端口被占用:1)在cmd命令行下输入以下命令:netstat  -aon|findstr "1099",回车之后就可以看见列表中的PID,然后根据PID在电脑的任务管理器中查看对应的占用程序,然后将其关闭即可;2)然后根据查询的PID找到对应的进程,我们可以看到占有1099这个程序的进程ID,如:5264,继续输入命令【tasklist|findstr "5264"】,5264就是进程ID,现在知道是哪个进程占用的我们的端口,即可在任务管理器中杀掉该进程。

 

问题3:如果使用slave发送数据后,长时间无响应

问题排查:

1)查看发送的数据中是否存在csv参数文件,查看slave机器的bin目录下是否有该文件;

2)查看建立的tcp采样器中属性“TCPClient classname”处是否添加协议:org.apache.jmeter.protocol.tcp.sampler.BinaryTCPClientImpl

 

问题4:如果你的JMeter返回数据是乱码

解决方法:在JMeter安装路径的bin目录下,打开文件jmeter.properties,把Sampleresult.default.encoding的值改为 utf-8 即可。

 

问题5:启动jmeter时,报错:Error occurred during initialization of VM Could not reserve enough space for object heap errorlevel=1

解决方法:1)bin目录下打开jmeter.bat文件,查找set HEAP,将set HEAP=-Xms128m -Xmx512m修改为set HEAP=-Xms512m -Xmx512m;2)重新启动jmeter.bat即可

 

问题6:当jmeter用作数据库API测试时,如果数据库接口中参数中传递一个数组,如getApps(int nu, int appID[ ]),实际使用过程中报语法错误

解决方法:可尝试在调用该接口传参中加入关键字“ARRAY”,如getApps(3, ARRAY[7,8])

 

 

 

 

 

 

 

 

标签:bin,查看,jdk,步骤,1099,linux,jmeter,分布式
From: https://www.cnblogs.com/snow1211/p/17287645.html

相关文章

  • Jmeter搭建分布式压测环境
    最近在做性能测试,本来以为一台压力机就够啦,但是在压测一个查询接口的时候,当TPS达到500多的时候就开始报错,经过定位是压力机出现啦瓶颈,于是决定对压力机做一下分布式,经过调试环境部署成功,再次压测时候问题解决。下面记录一下部署分布式环境的过程。使用的工具及版本:JDK:1.8.0_211......
  • 分布式定时任务调度框架实践
    vivo互联网技术微信公众号 作者:陈王荣分布式任务调度框架几乎是每个大型应用必备的工具,本文介绍了任务调度框架使用的需求背景和痛点,对业界普遍使用的开源分布式任务调度框架的使用进行了探究实践,并分析了这几种框架的优劣势和对自身业务的思考。一、业务背景1.1为什么需要使......
  • 分布式系统——并发条件下如何保证缓存与DB数据一致性
    什么是数据一致性我们常说的数据一致性指的是在程序运行过程中本地缓存、分布式缓存、数据库三者之间的数据一致性常见的本地缓存有hashmap、currenthashmap、guavacache、caffeine分布式缓存常见的有redis、memcache常见数据不一致常见有:本地缓存与mysql不一致redis......
  • 分布式系统——分布式ID方案
    分布式ID介绍在分布式系统中,我们经常需要生成全局唯一的标识符,例如订单号,用户id,消息id等。这些标识符通常被称为分布式id。分布式id有以下几个常见的要求:全局唯一:不同的节点或服务不能生成重复的id。高性能:生成id的速度要快,不能成为系统的瓶颈。低延迟:生成id的过程要尽可能简......
  • 分布式系统——基于Redis的分布式锁的实现
    分布式锁的介绍分布式锁是分布式系统中用于协调多个进程或线程之间并发访问共享资源的一种机制。在分布式系统中,由于各个节点之间的通信存在延迟、故障等问题,可能会导致数据的不一致性。为了保证数据的一致性,需要使用分布式锁来协调各个节点的并发访问。在分布式系统中,多个节点......
  • 大数据经典论文解读 - 分布式锁 Chubby
    Chubby在谷歌“三驾马车”中3个系统都是单Master系统,这个Master是系统的单点,一旦Master故障集群就无法提供服务。使用BackupMaster,通过监控机制进行切换。但是:如何实现BackupMaster和Master完全同步?监控程序也是单点,如何确定是Master宕机还是监控程序到Master的网络断了?后者......
  • linux安装Elasticsearch详细步骤
     坑都已经踩好了 照着步骤一次成功  不多废话 走起# ## 安装java运行环境elasticsearch是用Java实现的 跑elasticsearch必须要有jre支持 所以必须先安装jre传送门:# ## 安装elasticsearch-7.8.1也可以去官网下载 https://www.elastic.co/cn/downloads/elasti......
  • Jmeter的http信息头管理器设置
    什么是信息头:请求头什么时候用?cookietoken或者是其他的信息的时候;我们的场景设计?反爬虫添加信息头--模拟浏览器去发送请求--user-agent  ......
  • Apache JMeter压力测试工具的安装与使用
    官网下载https://jmeter.apache.org/download_jmeter.cgi然后解压即可运行双击bin/jmeter.bat汉化在软件里选择语言重启就会还原,所以这里直接改配置文件来永久汉化打开bin/jmeter.properties找到#language行,大概在第39行,改成language=zh_CN保存后重启jmeter即可使用教......
  • jmeter同线程、跨线程 cookie的处理
    一、同一个线程内,推荐使用cookie管理器自动获取在登录之后添加HTTPCookie管理器,会自动记录cookie并且在之后的请求中,自动将保存的cookie信息加上cookie管理器里,什么都不用修改登录superman之后,进行创建普通用户,会发现cookie的数据已经自动填充但是我这个还是报错了,是为啥?......