在性能測試時,涉及到註冊等需要手機號碼的接口,且此手機號碼不能重複以及在數據庫中已存在,通過什麼方式可以解決這個問題?
方案一
通過另外一個接口將創建信息註銷或刪除
如:註冊接口可通過註銷的方式將該手機號碼
優點:
- 號碼可重複使用
缺點:
- 需要額外增加另外一個接口 數據庫中業務可能注
- 銷接口僅僅將is_delete的狀態置爲1,導致實際的請求和業務場景不一致
- 大概率產生熱點數據
方案二
通過數據庫操作將已註冊的信息刪除
如使用jmeter的JDBC 後置處理程序
優點
- 號碼可重複使用
缺點
- 需要額外增加對業務數據庫的操作
- 數據庫添加用戶信息等不一樣,sql語句複雜且可能產生髒數據
- 大概率產生熱點數據
方案三
jmeter中使用BeanShell 預處理生成電話號碼
sql如下:
//${__time(/100000,)}由函數助手生成,見下圖
ts=String.valueOf(${__time(/1000,)});
String []t = ts.split("");
// 電話號碼第1-3位
String phone = String.valueOf(${__Random(1,9,)}) + String.valueOf(${__Random(0,9,)}) + String.valueOf(${__Random(0,9,)});
// 電話號碼第4-10位
for (int i=3; i<10; i++) {
phone = phone + t[i];
}
// 電話號碼第11位
phone = phone + String.valueOf(${__Random(0,9,)});
//將phone設置爲變量
vars.put("phone",phone);
ps:因爲當前服務校驗電話號碼僅校驗是否爲11位數字,故可以使用以上的方式
優點
- 可自動生成手機號碼,且不需要額外對服務和數據庫進行操作
缺點
- 併發量大的時候會出現重複手機號,且分佈式運行時更加明顯
100個線程併發,循環100次,錯誤率0.4%,如果線程數增大時錯誤率猛增
方案四
實現一個唯一手機號碼生成服務
使用的是一個美團開源的代碼上進行改造Leaf ,號段模式
優點
- 生成手機號碼重複率極低
缺點
- 需要額外進行接口請求
- 需要在線上環境部署該服務
100個線程併發,循環100次,錯誤率0%
綜合評估,選擇方案四做爲此次性能測試的手機號碼生成