错误1
java.io.FileNotFoundException:rmi_keystore.jks
文件校验问题
1、不进行文件校验,打开 [ jmeter 安装目录 ]\bin\jmeter-server.bat 文件
# 在 jmeter.properties 文件中,修改以下内容:
server.rmi.ssl.disable=true
2、运行 create-rmi-keystore.bat (Windows)/ create-rmi-keystore.sh (Linux) 文件并自行填写相关信息,运行后,bin 目录下会多出一个 rmi_keystore.jks 文件,然后将这个文件拷贝到想要运行的 slave 机上,就可以不使用方法1
错误2
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)
set rmi_host=-Djava.rmi.server.hostname=本机IP
// 修改set ARGS=,在其后增加一项 %rmi_host%,与其他项以空格间隔
if not defined JMETER_COMPLETE_ARGS (
set ARGS=%JAVA9_OPTS% %DUMP% %HEAP% %VERBOSE_GC% %GC_ALGO% %DDRAW% %SYSTEM_PROPS% %JMETER_LANGUAGE% %RUN_IN_DOCKER% %rmi_host%
) else (
set ARGS=
)
错误3
Error in rconfigure() method java.rmi.ConnectException:Connection refused to host
1、查看端口是否被占用
1、更换端口
# windows doc 命令
netstat -ano | findstr "1099"
tasklist | findstr "1099"
错误4
java.net.ConnectException:Connection timed out:connect
由于连接被拒绝,这意味着防火墙可能已切断连接
需要在JMeter和目标服务器之间打开端口
错误5
Response too large to be displayed. Size: 412152 > 204800
未设置察看结果树的大小
1、打开 [ jmeter 安装目录 ]\bin\user.property 文件
# 在 user.property 中,添加以下内容并重启jmeter:
view.results.tree.max_size=0
2、右击测试用例——添加——监听器——保存响应到文件, 填写要保存的文件名
3、将文件中的返回结果粘贴到此用例的响应断言中
错误6
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
错误7
Bad call to remote host
1、检查 salve 机器上的 jmeter-server 是否启动
2、检查 JMeter.properties 中 remote_hosts 的配置是否错误
1、启动 salve 机器上的 jmeter-server
2、正确配置 JMeter.properties 中 remote_hosts
错误8
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毫秒,能解决报错问题,问题还是没有真正解决
# 相应时间是正常测试的 2-3倍,响应时间变长
httpclient.timeout=60
错误9
Server failed to start: java.rmi.RemoteException: Cannot start. *** is a loopback address.
An error occurred: Cannot start. *** is a loopback address.
没有指定主机导致这个错误
1、修改 hosts 文件
# 将127.0.0.1 换成Linux机器的ip地址
127.0.0.1 besttest
# 或者将 127.0.0.1 besttest 这一行给注释(#),在下面另起一行:
# 非 root 用户获取 IP 地址的命令,ifconfig 只有 root 用户可以直接用
ip besttest /sbin/ifconfig
2、打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
# server_ip 为每台server自己的ip
RMI_HOST_DEF=-Djava.rmi.server.hostname=server_ip
错误10
Waiting for possible shutdown message on port 4445
在 master 跑测试脚本时,会一直提示如下信息,导致测试一直跑不起来
这个是用于监听shutdown message的,如果不需要,可以直接设置为0即可
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
# 每台机器要在同一局域网下,最好操作系统保持一致,不然运行master 执行脚本有可能会提示拒绝连接的错误
# 在 jmeter.properties 文件中,添加以下内容:
jmeterengine.nongui.port=0
错误11
Could not reserve enough space for 2097152KB object heap
errorlevel=1
Jmeter 内存不足
打开 [ jmeter 安装目录 ]\bin\jmeter.bat 文件
# 在 jmeter.bat 文件中,修改以下内容:
set HEAP=-Xms1g -Xmx1g
错误12
could not find ApacheJmeter_core.jar
找不到 jdk 环境
1、正确安装对应版本的 jdk
2、正确设置环境变量
错误13
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
错误14
运行成功,响应断言也正确通过,但是察看结果树里为空
模式(Mode)(采样结果发送模式)默认是Standard,在采样结果产生后立即发送
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
# 在 jmeter.properties 文件中,注释以下内容:
mode=Standard
错误15
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,证明猜想
无
错误16
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
MaxUserPort 65334
TcpTimedWaitDelay 30
错误17
jmeter脚本运行的过程中,服务器性能参数没有明显变化 (CPU,内存,I/O),但request的响应时间很长。
观察jmeter agent机器网络使用情况,网络使用持续达到带宽的限制峰值。request 发送的过程中pending在网络中,实际并发的request并没有同一时间到达服务器,所以服务器没有明显变化。
提高jmeter agent机器网络带宽。
错误18
java.io.IOException: Error writing to server
java.net.SocketException: Connection reset
可能是本机的 JVM 太小了
打开 [ jmeter 安装目录 ]\bin\jmeter.bat 文件
# 在 jmeter.bat 文件中,修改以下内容:
set HEAP=-Xms256m -Xmx1024m
set NEW=-XX:NewSize=128m -XX:MaxNewSize=512m
错误19
java.net.SocketException: Unrecognized Windows Sockets error: 0: recv failed
无
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
# 在 jmeter.properties 文件中,修改以下内容:(错误率降到0.25%)
javax.net.debug=ssl:handshake:verbose
错误20
java.net.SocketTimeoutException: Read timed out
无
打开 [ jmeter 安装目录 ]\bin\jmeter.properties 文件
# 在 jmeter.properties 文件中,修改以下内容:(错误率降到0)
javax.net.debug=true
错误21
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}可用于检测最后一个取样器是否成功执行
错误22
java.lang.IllegalStateException: Engine is busy - please try later
1、可能是防火墙规则被阻止
2、控制机、执行机未设置需要连接的IP
1、关闭控制机、执行机的防火墙
2、打开 [ jmeter 安装目录 ]\bin\jmeter-server 文件
# 在 jmeter-server 文件中,控制机和执行机都需要设置需要连接的 IP
# 例如:当前机器(控制机或者执行机)的 IP 为 192.168.40.15,添加以下内容:
RMI_HOST_DEF=-Djava.rmi.server.hostname=192.168.40.15
3、打开 [ jmeter 安装目录 ]\bin\system.properties 文件
# 在 system.properties 文件中,控制机和执行机都需要设置需要连接的 IP
# 例如:当前机器(控制机或者执行机)的 IP 为 192.168.40.15,添加以下内容:
java.rmi.server.hostname=192.168.40.15
错误23
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 本身的影响