框架:
SpringCloud2.1、SpringSecurity、mybatisplus3.2.0
壓測登陸接口:
工具:jemeter
參數: threads:800 ,rame-up:5s,Loopcount:5
優化前:執行半分鐘後系統卡死
優化後:90%請求在5秒以內,TPS177,無錯誤
優化思路
- 登陸接口邏輯簡單,請求時間過長,所以使用Arthas中trace命令跟蹤方法調用執行時間。
- 優化前Arthas跟蹤方法調用時間,發現PasswordEncoderFactories創建的PasswordEncoder實例中encode方法執行時間過長,所以自定義PasswordEncoder實現類。
- 優化後效果