记一次jmeter压测的坑

最近做了一个安全传输模块,因为怕对性能有较大影响,因此测试安排了针对性的压测
压测的过程出现了一点小问题

发现失败率特别高,测试怀疑是服务端出了错,但是我查看日志发现没有报错。后面我观察TCP链接数排除了服务端的嫌疑

我发现跑着跑着,tcp链接数就突然就降低下来,也就是这个时候jmeter显示的错误率急剧升高。因此排除了服务端的嫌疑,然后让测试把日志输出打开,果然打开日志输出后,发现了大量的错误

拿上面的错误信息到百度找,找到如下答案

Windows 提供给 TCP/IP链接的端口为 1024-5000,并且要四分钟来循环回收他们。就导致我们在短时间内跑大量的请求时将端口占满了。

又找到如下解决方法


增加动态分配到客户端TCP/IP 套接字连接的临时端口的上限

1.cmd中,用regedit命令打开注册表
2.在 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters下,
  1)右击parameters,添加一个新的DWORD,名字为MaxUserPort
        2)然后双击MaxUserPort,输入数值数据为65534,基数选择十进制
3.重启电脑

降低客户端TCP/IP 套接字连接的超时值

1. 启动注册表编辑器。
2. 在注册表中,浏览到并单击以下注册表项。
HKEY_LOCAL_MACHINE/SYSTEM/CurrentControlSet/Services/Tcpip/Parameters
3. 在“编辑”菜单中单击“新建”、“DWORD 值”,然后添加以下注册表值,以缩短关闭连接时,该连接处于 TIME_WAIT 状态的时间。当连接处于 TIME_WAIT 状态时,套接字对无法重新使用.

测试尝试过上面的方法是有效的,但是这个有效也是有限度的,如果把并发线程不断调大,还是会出现上面的问题,不过一般的小压测还是可以应付了。

  • 4
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JMeter是一款非常强大的力测试工具,可以用于对Web应用程序、Web服务、数据库等进行性能测试。在进行实际的压测过程中,文档录是非常重要的,可以帮助团队成员了解测试的目的、过程和结果。以下是一些常见的JMeter压测文档录内容: 1. 测试目标和范围:明确测试的目标和范围,例如测试的是哪个应用程序、测试的功能点、预期的用户并发量等。 2. 测试计划:录测试计划的详细信息,包括测试场景、测试数据、测试脚本等。可以包括脚本编写过程中的思路和方案。 3. 测试环境配置:录测试环境的配置信息,包括服务器硬件配置、操作系统版本、JDK版本等。这些信息可以帮助其他人在复现测试结果时保持一致的环境。 4. 测试步骤:录进行压测的具体步骤,包括启动JMeter、导入测试计划、配置线程组、设置断言等。步骤应该尽量详细,以便他人能够按照文档进行操作。 5. 测试结果分析:录测试运行结束后的结果分析,包括响应时间、吞吐量、错误率等指标。可以使用图表或表格的形式展示结果,方便其他人快速了解测试结果。 6. 总结和建议:对测试过程进行总结,并提出改进的建议。可以录测试过程中遇到的问题、解决方案和经验教训,为以后的压测提供参考。 需要注意的是,文档录应该尽量清晰、简洁,使用易于阅读和理解的语言。同时,及时更新文档以反映实际情况的变化。这样可以帮助团队成员更好地理解和利用文档中的信息。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值