linux jmeter 关闭服务,Linux Jmeter性能压测常见错误排查及解决方法

排除错误日志一般方法:查看脚本执行错误日志---->接口返回异常查看服务器日志,检查是否是参数导致的问题或代码逻辑问题

---->出现网络相关,先优化压测及网络配置再压测

1.Linux下性能压测报错,如何查看错误日志?

在压测机的jmeter安装目录/bin/user.properties末尾加上:

jmeter.save.saveservice.output_format=xml

jmeter.save.saveservice.response_data=true

jmeter.save.saveservice.samplerData=true

jmeter.save.saveservice.requestHeaders=true

jmeter.save.saveservice.url=true

jmeter.save.saveservice.responseHeaders=true

执行脚本报错后停止【因为生成的jtl文件太大】,将jtl拷贝到本地,以查看结果树的监听器打开,即可看到接口报错日志;

2.压测接口返回:java.net.NoRouteToHostException: Cannot assign requested address,端口未释放导致socket连接失败

解法一:

(1)调低端口释放后的等待时间,默认为60s,修改为15~30s。

/proc/sys/net/ipv4/tcp_fin_timeout

(2) 修改 tcp/ip 协议配置,通过配置

/proc/sys/net/ipv4/tcp_tw_reuse,默认为0,修改为1,释放TIME_WAIT端口给新连接使用。

(3)  修改 ctp/ip 协议配置,快速回收socket资源,默认为0.修改为1。

/proc/sys/net/ipv4/tcp_tw_recycle

解法二:

(1)/etc/sysctl.conf,在文件中添加如下内容:

net.ipv4.ip_local_port_range = 1024 65535 # 允许使用到的端口范围

输入sysctl -p即生效

3.日志中出现too manay open files或者类似信息,原因:服务器允许的最大句柄数、当前用户允许的最大句柄数或者当前线程允许的最大句柄数没有调整

解决方法:

(1)在/etc/security/limits.conf文件最后加上如下语句:

* soft nofile 65535

* hard nofile 65535

* soft nproc 65535

* hard nproc 65535

(2)执行 service sshd restart 重启sshd服务即可生效

若不生效,执行下述命令:

(3)echo ulimit -n 65535 >>/etc/profile

(4)source /etc/profile    #加载修改后的profile

4. 客户端连接后发现非常多的TIME_WAIT状态连接,原因:系统中并发非常大,导致客户端释放连接后,在服务器端未回收该连接,该 连接处于TIME_WAIT状态

解决方法:

(1)/etc/sysctl.conf,在文件中添加如下内容:

net.ipv4.tcp_max_tw_buckets = 180000     # 设置tcp连接时TIME_WAIT个数,默认为180000,常用

只有 60000 多个端口可用的情况下,配置为 net.ipv4.tcp_max_tw_buckets = 55000

输入sysctl -p即生效

原文:https://www.cnblogs.com/jiangger/p/14151563.html

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值