这篇笔记不讲性能测试的指标拆分。。。就写一些平时可能会出现,但出现概率不高的问题的解决方案。
1.测试场景问题解决,测的时候用了一波用户的imei数据,发现用户数据不太准确,有imei尾数不正确的,有用idfa做imei存储的。。这会导致系统返回错误结果。为了兼容这种问题(不然图表会不好看,问题也不好排查),性能测试脚本加了一些判断。
正则是用来判断是否是数字,而getlastbit函数主要是用来处理imei末尾校验不正确的问题,强制给他附一个正确的imei给用户。
import java.util.regex.Pattern;
private static String getLastBit(String imei){
if (imei.length() == 14) {
char[] imeiChar = imei.toCharArray();
int resultInt = 0;
for (int i = 0; i < imeiChar.length; i++) {
//奇数位
int a = Integer.parseInt(String.valueOf(imeiChar[i]));
i++;
//偶数位
final int temp = Integer.parseInt(String.valueOf(imeiChar[i])) * 2;
//分别计算个位数和十位数之和
final int b = temp < 10 ? temp : temp - 9;
resultInt += a + b;
}
resultInt %= 10;
resultInt = resultInt == 0 ? 0 : 10 - resultInt;
return resultInt + "";
}else{
return "";
}
}
String imei = vars.get("imei");
private Pattern PATTERN_IMEI = Pattern.compile("^\\d{15}$");
if (imei!=null) {
if (PATTERN_IMEI.matcher(imei).matches()){
String subIemiBefore = imei.substring(0,14);
String imeiRes = subIemiBefore + getLastBit(subIemiBefore);
if (!imei.equals(imeiRes)){
imei = imeiRes;
vars.put("imei",imei);
}
}
else{
vars.put("imei","");
}
}
但我们的硬件条件相对简陋,我本地的CPU直接爆掉了。。。
开始以为这是无法解决的硬伤,后来想了一想,我觉得我就,jmeter.bat配置可能也设置得有问题。newSize之前设置得太暴力了,没有合理分配初始块)。
SET HEAP = -Xms1024M -Xmx4096M -XX:MaxMetaspaceSize=1024m
SET NEW = -XX:NewSize=10m -XX:MaxNewSize=128m
//然后把下面这一段注释掉了,因为我总觉得自己配置没生效
if not defined HEAP (
rem See the unix startup file for the rationale of the following parameters,
rem including some tuning recommendations
set HEAP=-Xms1g -Xmx1g -XX:MaxMetaspaceSize=256m
)
果然经过调整以后,跑80的并发,本地的CPU和内存占用也非常小。之前跑60的并发本地就挂了,现在80并发都毫不费力。。。完成了对服务器性能的监控