Jmeter 问题锦集
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Jmeter 问题锦集相关的知识,希望对你有一定的参考价值。
参考技术A java.io.FileNotFoundException:rmi_keystore.jks文件校验问题
1、不进行文件校验,打开 [ jmeter 安装目录 ]\bin\jmeter-server.bat 文件
2、运行 create-rmi-keystore.bat (Windows)/ create-rmi-keystore.sh (Linux) 文件并自行填写相关信息,运行后,bin 目录下会多出一个 rmi_keystore.jks 文件,然后将这个文件拷贝到想要运行的 slave 机上,就可以不使用方法1
Error in rconfigure() method java.rmi.ConnectException: Connection refused to host: 192.168.xxx.xxx; nested exception is:
java.net.ConnectException: Connection timed out: connect
1、192.168.xxx.xxx 这个IP 可能是虚拟网卡的 IP,关闭所有的虚拟网卡,只保留本地网络
2、检查slave服务器的防火墙是否打开,需要关闭
3、通信双方的机器没有识别到有效的远程IP,考虑将远程方法调用服务器的主机IP进行固定设置,再作效果检查
4、开始测试,但是测试速度非常慢,测试结果也是非常大的值,检查slave服务器和被测试服务器之间是否可以 ping 通地址
第3点分析相应解决方法:
Master机修改 jmeter.bat (windows)/ jmeter.sh (Liunx)
Error in rconfigure() method java.rmi.ConnectException:Connection refused to host
1、查看端口是否被占用
1、更换端口
java.net.ConnectException:Connection timed out:connect
由于连接被拒绝,这意味着防火墙可能已切断连接
需要在JMeter和目标服务器之间打开端口
Response too large to be displayed. Size: 412152 > 204800
未设置察看结果树的大小
1、打开 [ jmeter 安装目录 ]\bin\user.property 文件
2、右击测试用例——添加——监听器——保存响应到文件, 填写要保存的文件名
3、将文件中的返回结果粘贴到此用例的响应断言中
Not able to find Java executable or version. Please check your Java installation. errorlevel=2
1、errorlevel=1,当前系统安装的 jdk 版本过低
2、errorlevel=2,没有配置 jdk 环境变量所致
3、errorlevel=3,当前系统安装的 jdk 版本过低,不符合 jmeter 要求所致
通用方法:
配置对应这个 jmeter 版本的 jdk 版本的环境变量
第1点分析,其他解决方法:
打开 jmeter.bat 文 件,注释 set DUMP=-XX:+HeapDumpOnOutOfMemoryError
Bad call to remote host
1、检查 salve 机器上的 jmeter-server 是否启动
2、检查 JMeter.properties 中 remote_hosts 的配置是否错误
1、启动 salve 机器上的 jmeter-server
2、正确配置 JMeter.properties 中 remote_hosts
1、Non HTTP response message: The target server failed to respond
2、Non HTTP response code: java.net.SocketException
调整超时时间,jmeter 的 http 请求中,工具会默认勾选 Use KeepAlive ,在运行时,jmeter.properties 中的 httpclient.timeout 设置默认是注销的,也就是连接空闲,立马断开
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
根据情况设置10-60毫秒,能解决报错问题,问题还是没有真正解决
Server failed to start: java.rmi.RemoteException: Cannot start. *** is a loopback address.
An error occurred: Cannot start. *** is a loopback address.
没有指定主机导致这个错误
1、修改 hosts 文件
2、打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
Waiting for possible shutdown message on port 4445
在 master 跑测试脚本时,会一直提示如下信息,导致测试一直跑不起来
这个是用于监听shutdown message的,如果不需要,可以直接设置为0即可
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
Could not reserve enough space for 2097152KB object heap
errorlevel=1
Jmeter 内存不足
打开 [ jmeter 安装目录 ]\bin\jmeter.bat 文件
could not find ApacheJmeter_core.jar
找不到 jdk 环境
1、正确安装对应版本的 jdk
2、正确设置环境变量
jmeter.gui.action.RemoteStart: Failed to initialise remote engine java.rmi.ConnectException: Connection refused to host: 127.0.0.1; nested exception is:
配置了 127.0.0.1,但是未开启本机的 jmeter-sever.bat/jmeter-sever
开启本机的 jmeter-sever.bat/jmeter-sever
运行成功,响应断言也正确通过,但是察看结果树里为空
模式(Mode)(采样结果发送模式)默认是Standard,在采样结果产生后立即发送
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
Response code: Non HTTP response code: java.net.SocketTimeoutException
Response message: Non HTTP response message: connect timed out
发生该错误时,jmeter已经连接上服务器,查看load time没有超过设定的request timeout时间,错误可能的原因是,服务器那边未处理该线程的请求,或者为保证服务能力,断掉了连接。
为了验证该猜想,持续大于半小时向服务器发送该并发数量的请求,一段时间后,request收到503的response,证明猜想
无
Java.NET.BindException: Address already in use: connect
短时间内new socket操作很多,而socket.close()操作并不能立即释放绑定的端口,而是把端口设置为TIMEWAIT 状态,过段时间(默认240s)才释放,(用netstat -na可以看到),最后系统资源耗尽(windows上是耗尽了pool of ephemeral ports ,这段区间在1024-5000之间)
在运行 JMeter agent 的机器上,添加注册表条目HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters
jmeter脚本运行的过程中,服务器性能参数没有明显变化 (CPU,内存,I/O),但request的响应时间很长。
观察jmeter agent机器网络使用情况,网络使用持续达到带宽的限制峰值。request 发送的过程中pending在网络中,实际并发的request并没有同一时间到达服务器,所以服务器没有明显变化。
提高jmeter agent机器网络带宽。
java.io.IOException: Error writing to server
java.net.SocketException: Connection reset
可能是本机的 JVM 太小了
打开 [ jmeter 安装目录 ]\bin\jmeter.bat 文件
java.net.SocketException: Unrecognized Windows Sockets error: 0: recv failed
无
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
java.net.SocketTimeoutException: Read timed out
无
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
For performance it is advised to check "Interpret Condition as Variable Expression"
and use __jexl3 or __groovy evaluating to true or false or a variable that contains true or false.
$JMeterThread.last_sample_ok) can be used to test if last sampler was successful
对于4.x之后的版本 JMeter 中的 If Controller,在Expression输入框中直接输入判断的表达式,如1 == 1、$threadNum > 2,而不做求值计算(true/false)就执行JMeter是没有效的,达不到预期的效果。采用JMeter比较早期的版本(如:2.x版本),直接就写判断的表达式,并没有作真假求值运算也能被识别
1、在Expression输入框中,建议将判断条件解释为变量表达式,并使用__jexl3函数或__groovy函数对该变量表达式求值为true/false
2、可输入值为true/false的变量
3、$JMeterThread.last_sample_ok可用于检测最后一个取样器是否成功执行
java.lang.IllegalStateException: Engine is busy - please try later
1、可能是防火墙规则被阻止
2、控制机、执行机未设置需要连接的IP
1、关闭控制机、执行机的防火墙
2、打开 [ jmeter 安装目录 ]\bin\jmeter-server 文件
3、打开 [ jmeter 安装目录 ]\bin\system.properties 文件
Response code: Non HTTP response code:org.apache.http.conn.ConnectTimeoutException
Response message: Non HTTP responsemessage: Connect to 10.15.107.112:9089 timed out
Non HTTPresponse code 说明没有收到来自服务器的 response。
导致 ConnectTimeoutException 错误的可能有 JMeter 本身问题,也可能是服务器问题。
通过分布式运行 JMeter 的方式来消除 JMeter 本身的影响
以上是关于Jmeter 问题锦集的主要内容,如果未能解决你的问题,请参考以下文章