Jmeter 压力测试笔记(3)--脚本调试/签名/cookie/提升吞吐量/降低异常率/提升单机并发性能

import XXXsign.Openapi2sign;---导入jar包中的签名方法
String str1 = "12121";		---需要被签名的字段;向开发了解需要哪些哪些字段
String result = "";		--定义结果变量
result = new Openapi2sign().md5Encode(str1);  ---调用签名的方法对签名字段进行签名
System.out.println(result);	---输出签名后的字段
vars.put("sign",result.toString());  ----设置全局遍历sign的值为签名后的值。需要对签名结果进行

  

  在编写好基础脚本,以及请求参数后,开始进行调试脚本:遇到了第一个问题:

  请求签名校验失败:

  通过各种上网查找资料:终于搞定:步骤如下:

    1,向开发了解前端签名规则,算法,获取前端签名XXXsign.jar 包。

    2,将该包加入 Jmeter/lib目录下。

    3,由于每个http请求生成的签名都不一样,所以需要在每个需要签名的http请求中添加 前置处理器--》BeanShell 取样器,和调试取样器(调试用,正式跑脚本时删除)。

    4,编写脚本,生成签名,并设置签名变量,在http请求头配置元件中调用

import XXXsign.Openapi2sign;    ---导入jar包中的签名方法
String str1 = "12121";		  ---需要被签名的字段;向开发了解需要哪些哪些字段
String token = ""          ----签名定义的token
String time = ${__time(/1000)} ----签名需要的时间参数
String str00 = token + time + str1 ---拼接成最终的签名字段 String result = "";   --定义结果变量 result = new Openapi2sign().md5Encode(str00);   ---调用签名的方法对签名字段进行签名 System.out.println(result);     ---输出签名后的字段,正式执行时,注释这行 vars.put("sign",result.toString()); ----设置全局遍历sign的值为签名后的值。需要对签名结果进行

 

  

 

 

 5,调试好的脚本,在调试取样器的结果和请求的header中都可以看到请求的签名字符串

 

 

 

 

 

================================================

 

  调试好签名以后:遇到第二个cookie校验失败。

    当需要执行大批量用户并发业务测试时,不适合使用登录接口获取登录态。再更新cookie

  我使用的办法是,找开发奖cookie 生成规则固定。好用于进行接口测试。

  cookie固定的规则是:

    sid=用户ID+‘sid’,uid=用户ID,device_id=test(固定为test)

  找DBA将该规则写入Redis。

  在Jmeter 线程组中添加cookie管理器:

  在cookie管理器中:设置固定的cookie格式。 userid从csv数据文件中传输。用来模拟多用户请求业务场景。

  

 

 

 

  经过测试:ok

 

======================================================

  提升吞吐量:

  脚本调试在windows 10 上进行。测试时,发现吞吐量总是上不去,且异常率特别高55%

  上网一阵猛搜索~ 感觉自己是个工具人。哈哈~

  

  首先根据自己电脑内存,加大了jvm内存,一口气直接加到4G,开心~

  并且进行了如下配置:

   修改注册表: 提升TCP连接端口,减少tcp回收时间:

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

解决办法如下:

cmd中,用regedit命令打开注册表

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

在HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters下:

右击parameters,添加一个新的DWORD,名字为MaxUserPort

然后双击MaxUserPort,输入数值数据为65534,基数选择十进制

第二步:降低客户端 TCP/IP 套接字连接的超时值(默认值为 240 秒)

在注册表中,浏览到并单击以下注册表项。

HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters

在“编辑”菜单中单击“新建”、“DWORD 值”,然后添加以下注册表值,以缩短关闭连接时,该连接处于 TIME_WAIT 状态的时间。当连接处于 TIME_WAIT 状态时,套接字对无法重新使用:

右击parameters,添加一个新的DWORD,名字为TcpTimedWaitDelay

然后双击TcpTimedWaitDelay,输入数值数据为一个 30 到 240 之间的数字,基数选择十进制--设置30秒

重启电脑

完成以上步骤后,吞吐量大大上升,异常率大大降低。

 

====================================

提升单机并发性能

  经过提升内存和tcp连接数、以及修改tcp连接时间后。机器的性能已经被我们压榨的差不多了。现在我们要调试的我们的脚本。

   1,线程数:每个线程数都占用一定的内存(我自己测试3到4M:猜的),线程数不要超过给定的jvm内存,否则会卡,会慢。吞吐量下降,异常率提升。并发量下降,连接数下降等等。

   2,预热时间:我一般设置为30秒。实际线程设置比较多时,大于500,30秒并不能完全启动。建议大家按500线程数30秒的时间来设置。

   3,响应,断言,查看结果树,这些东西都关掉。

   4,精确吞吐量定时器:这个在部分场景,需要对接口的请求次数限定时有用。

   

 

 

 

 

 

 

 

 

 

 

posted @ 2020-04-10 15:42  烟七七  阅读(1030)  评论(0编辑  收藏  举报