排除错误日志一般方法:
查看脚本执行错误日志->接口返回异常查看服务器日志,检查是否是参数导致的问题或代码逻辑问题->出现网络相关,先优化压测及网络配置再压测
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连接失败
解决方法一:
调低端口释放后的等待时间,默认为60s,修改为15~30s。
/proc/sys/net/ipv4/tcp_fin_timeout
修改 tcp/ip 协议配置,通过配置
/proc/sys/net/ipv4/tcp_tw_reuse,默认为0,修改为1,
释放TIME_WAIT端口给新连接使用。
修改 ctp/ip 协议配置,快速回收socket资源,默认为0.修改为1。
/proc/sys/net/ipv4/tcp_tw_recycle
解决方法二:
/etc/sysctl.conf,在文件中添加如下内容:
net.ipv4.ip_local_port_range = 1024 65535 # 允许使用到的端口范围
输入sysctl -p即生效
3、日志中出现too manay open files或者类似信息
原因:服务器允许的最大句柄数、当前用户允许的最大句柄数或者当前线程允许的最大句柄数没有调整
解决方法:
在/etc/security/limits.conf文件最后加上如下语句:
* soft nofile 65535
* hard nofile 65535
* soft nproc 65535
* hard nproc 65535
执行 service sshd restart 重启sshd服务即可生效
若不生效,执行下述命令:
echo ulimit -n 65535 >>/etc/profile
source /etc/profile #加载修改后的profile
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】
4、客户端连接后发现非常多的TIME_WAIT状态连接
原因:系统中并发非常大,导致客户端释放连接后,在服务器端未回收该连接,该 连接处于TIME_WAIT状态
解决方法:
/etc/sysctl.conf,在文件中添加如下内容:
net.ipv4.tcp_max_tw_buckets = 180000 # 设置tcp连接时TIME_WAIT个数,默认为180000,常用
只有 60000 多个端口可用的情况下,配置为
net.ipv4.tcp_max_tw_buckets = 55000
输入sysctl -p即生效
5、压测过程中出现无法解析域名情况
需要到etc/hosts配置域名解析:epas IP 域名
下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!
最后: 可以在公众号:程序员小濠 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。
如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!