国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

淺談Spring Boot: 接口壓測及簡要優化策略

瀏覽:8日期:2023-08-12 08:41:25

工程做好之后,需要對接口進行壓力測試??梢宰约壕帉懢€程池模擬多用戶訪問測試,也可以使用jmeter進行壓測。jmeter的好處是測試方便,并且有完善的結果分析功能。本次采用jmeter進行壓力測試。

1.準備數據,為了測試準備200w條以上的數據。一個簡單的方法是使用下面的sql快速創建。

INSERT INTO table (user_name,address)

SELECT user_name, address FROM table;

但這樣創建的數據不同記錄的重復部分太多,和實際業務不太相符。一般業務上,除了主鍵之外還會有某一個字段是唯一,比如手機號,用戶名等。本次將user_name設置為唯一,簡單采用UUID的方式生成。

@RequestMapping('/create')public Integer createData(Integer password) {if (password != 1024) {return 0;}ThreadPoolExecutor poolExecutor = new ThreadPoolExecutor(10,20, 1, TimeUnit.MINUTES,new ArrayBlockingQueue<Runnable>(100000),Executors.defaultThreadFactory(), new ThreadPoolExecutor.CallerRunsPolicy());int max = 1000000;for (int i = 0; i < max; i++) {poolExecutor.execute(() -> {Date now = new Date();User user = new User();user.setStatus(0);user.setUserName(UUID.randomUUID().toString().replace('-', ''));user.setAddress('');user.setCreateTime(now);user.setUpdateTime(now);userService.saveUser(user);});}return 1;}

采用線程池技術來生成數據。部分參數參考自己的配置進行設置。我這里采用核心線程數10,最大線程數20,阻塞隊列容量10w,拒絕策略CallerRunsPolicy的參數來生成。

數據生成以后,確認下生成數量,可以看到所有的user_name都是不同的。

select count(*),count(distinct user_name) from user

淺談Spring Boot: 接口壓測及簡要優化策略

2.改造接口。為了測試方便,使用公共mapper。引入依賴

<dependency><groupId>tk.mybatis</groupId><artifactId>mapper-spring-boot-starter</artifactId></dependency>

修改啟動類MapperScan注解為import tk.mybatis.spring.annotation.MapperScan;

mapper接口繼承extends Mapper,(import tk.mybatis.mapper.common.Mapper;)。這樣就會為mapper生成insert,select等基本方法。

3.測試。

所測試的接口為

@RequestMapping(value = '/hello', method = {RequestMethod.POST})public List<User> getUser(User user) {return userService.getUserByUser(user);}

打開jmeter,通過Option選擇中文語言。創建測試計劃,這次僅對接口進行壓力測試。

測試參數選擇userName,并使用隨機生成的UUID,這樣可以保證最終訪問DB時不觸發任何緩存。

1.文件-新建測試計劃

2.編輯-添加-線程-線程組

3.選中線程組,編輯-添加-邏輯控制器-事務控制器

4.選中事務控制器,編輯-添加-取樣器-BeanShell 取樣器

5.選中事務控制器,編輯-添加-HTTP請求

6.選中BeanShell取樣器,將下面代碼復制到腳本框里面,內容即為設置user_name變量為UUID。

import java.util.UUID;UUID uuid1 = UUID.randomUUID();vars.put('user_name',(uuid1.toString()).toUpperCase().replaceAll('-',''));

淺談Spring Boot: 接口壓測及簡要優化策略

7.選中HTTP請求,設置如下,其中參數部分內容為:

名稱 值 userName ${user_Name}

這樣就可以將步驟6生成的參數傳遞為HTTP POST請求的參數了。

淺談Spring Boot: 接口壓測及簡要優化策略

添加結果樹,匯總報告等,最終結構:

淺談Spring Boot: 接口壓測及簡要優化策略

8.選中線程組,設置線程數等信息,詳細請參照官網:https://jmeter.apache.org/usermanual/index.html

淺談Spring Boot: 接口壓測及簡要優化策略

這里先設置線程數為2000,由于要壓力測試,設置Ramp-up為1秒,即1秒內啟動所有線程。

9.啟動線程組。在這里插入圖片描述

10.結果樹里面可以確認具體每次請求的參數:

淺談Spring Boot: 接口壓測及簡要優化策略

匯總報告里面可以查看總體信息:

淺談Spring Boot: 接口壓測及簡要優化策略

通過以上步驟,可以初步預估下系統各個接口的吞吐量等信息。第一次壓測中user_name自動沒有設置索引,可以通過一些方法來提高系統性能:

1.為user_name設置索引。

2.使用redis緩存,其一是緩存最近檢索數據,其二是將表中所有user_name存入緩存(Set),請求到來時首先去緩存中查看是否存在,只有存在的時候才去檢索DB。

3.若數據量過大,可采用布隆過濾器存儲user_name。

4.限流,這里只說API層面的,guava包下RateLimiterJ;自寫切面+Redis;Spring Cloud GateWay。

工程地址:https://github.com/showsys20/spring-demo-cm.git

以上這篇淺談Spring Boot: 接口壓測及簡要優化策略就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
相關文章:
主站蜘蛛池模板: 日韩欧美一区二区三区在线 | 99精品视频在线播放2 | 亚洲精品推荐 | 国产精品尹人在线观看免费 | 精品外国呦系列在线观看 | 色九九视频 | 欧美亚洲另类在线 | 九九精品视频一区在线 | 一区二区三区影院 | 色偷偷女男人的天堂亚洲网 | 国产精品黄在线观看免费 | 欧美一级欧美一级在线播放 | 国产精品成人不卡在线观看 | 国产在线精品成人一区二区三区 | 丁香伊人五月综合激激激 | 国产三级日产三级日本三级 | 美女张开腿让男生桶出水 | 成人18视频在线观看 | 国产一级做性视频 | 精品视频在线观看一区二区三区 | www.av免费| 成人性色大片 | 国产在线一区二区三区欧美 | 国产亚洲高清在线精品99 | 欧美一区二区三区在线视频 | 亚洲一级二级三级 | 成人免费国产欧美日韩你懂的 | 91色久 | 免费视频一区二区三区四区 | 国产成人精品免费视频大全五级 | 日本色哟哟 | 欧美成人午夜视频免看 | 成人a毛片久久免费播放 | 在线看欧美成人中文字幕视频 | 国产黄色大片网站 | 欧美成人精品一级高清片 | 国产精品视频免费播放 | 久久91av| 精品免费在线视频 | 亚洲日本va午夜中文字幕一区 | 午夜欧美成人久久久久久 |