当前位置:首页 » 网页前端 » jmeter回放脚本出现403错误
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

jmeter回放脚本出现403错误

发布时间: 2023-06-30 15:48:22

⑴ Jmeter 问题锦集

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 本身的影响