精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

SpringBoot異步接口實現:提高系統的吞吐量

開發 前端
異步請求能提高吞吐量,這個是建立在相同配置(這里的配置指的是:最大連接數、最大工作線程數)的情況下。因此并不是說任何接口都可以使用異步請求。

前言

Servlet 3.0之前:每一次Http請求都由一個線程從頭到尾處理。

Servlet 3.0之后,提供了異步處理請求:可以先釋放容器分配給請求的線程與相關資源,減輕系統負擔,從而增加服務的吞吐量。

在springboot應用中,可以有4種方式實現異步接口(至于ResponseBodyEmitter、SseEmitter、StreamingResponseBody,不在本文介紹內,之后新寫文章介紹):

  • AsyncContext
  • Callable
  • WebAsyncTask
  • DeferredResult

第一中AsyncContext是Servlet層級的,比較原生的方式,本文不對此介紹(一般都不使用它,太麻煩了)。本文著重介紹后面三種方式。

特別說明:服務端的異步或同步對于客戶端而言是不可見的。不會因為服務端使用了異步,接口的結果就和同步不一樣了。另外,對于單個請求而言,使用異步接口會導致響應時間比同步大,但不特別明顯。具體后文分析。

基于Callable實現

Controller中,返回一個java.util.concurrent.Callable包裝的任何值,都表示該接口是一個異步接口:

@GetMapping("/testCallAble")
public Callable<String> testCallAble() {
    return () -> {
        Thread.sleep(40000);
        return "hello";
    };
}

服務器端的異步處理對客戶端來說是不可見的。例如,上述接口,最終返回的客戶端的是一個String,和同步接口中,直接返回String的效果是一樣的。

Callable 處理過程如下:

控制器返回一個 Callable 。

  • Spring MVC 調用 request.startAsync() 并將 Callable 提交給 AsyncTaskExecutor 以在單獨的線程中進行處理。
  • 同時, DispatcherServlet 和所有過濾器退出 Servlet 容器線程,但response保持打開狀態。
  • 最終 Callable 產生結果,Spring MVC將請求分派回Servlet容器以完成處理。
  • 再次調用 DispatcherServlet ,并使用 Callable 異步生成的返回值繼續處理。

Callable默認使用SimpleAsyncTaskExecutor類來執行,這個類非常簡單而且沒有重用線程。在實踐中,需要使用AsyncTaskExecutor類來對線程進行配置。

基于WebAsyncTask實現

Spring提供的WebAsyncTask是對Callable的包裝,提供了更強大的功能,比如:處理超時回調、錯誤回調、完成回調等。本質上,和Callable區別不大,但是由于它額外封裝了一些事件的回調,所有,通常都使用WebAsyncTask而不是Callable:

@GetMapping("/webAsyncTask")
public WebAsyncTask<String> webAsyncTask() {
    WebAsyncTask<String> result = new WebAsyncTask<>(30003, () -> {
        return "success";
    });
    result.onTimeout(() -> {
        log.info("timeout callback");
        return "timeout callback";
    });
    result.onCompletion(() -> log.info("finish callback"));
    return result;
}

這里額外提一下,WebAsyncTask可以配置一個超時時間,這里配置的超時時間比全局配置的超時時間優先級都高(會覆蓋全局配置的超時時間)。

基于DeferredResult實現

DeferredResult使用方式與Callable類似,但在返回結果時不一樣,它返回的時實際結果可能沒有生成,實際的結果可能會在另外的線程里面設置到DeferredResult中去。

//定義一個全局的變量,用來存儲DeferredResult對象
private Map<String, DeferredResult<String>> deferredResultMap = new ConcurrentHashMap<>();

@GetMapping("/testDeferredResult")
public DeferredResult<String> testDeferredResult(){
    DeferredResult<String> deferredResult = new DeferredResult<>();
    deferredResultMap.put("test", deferredResult);
    return deferredResult;
}

如果調用以上接口,會發現客戶端的請求一直是在pending狀態——等待后端響應。這里,我簡單的將該接口返回的DeferredResult對象存放在了一個Map集合中,實際應用中可以設計一個對象管理器來統一管理這些個對象。

注意:要考慮定時輪詢(或其他方式)這些對象,將已經處理過或無效的DeferredResult對象清理掉(DeferredResult.isSetOrExpired方法可以判斷是否還有效),避免內存泄露。

這里我又寫了一個接口,模擬:

@GetMapping("/testSetDeferredResult")
public String testSetDeferredResult() throws InterruptedException {
    DeferredResult<String> deferredResult = deferredResultMap.get("test");
    boolean flag = deferredResult.setResult("testSetDeferredResult");
    if(!flag){
        log.info("結果已經被處理,此次操作無效");
    }
    return "ok";
}

其他線程修改DeferredResult的值:首先是從之前存放DeferredResult的map中拿到DeferredResult的值,然后設置它的返回值。當執行deferredResult.setResult之后,可以看到之前pending狀態的接口完成了響應,得到的結果,就是這里設置的值。

這里也額外說下:在返回DeferredResult時也可以設置超時時間,這個時間的優先級也是大于全局設置的。另外,判斷DeferredResult是否有效,只是一個簡單的判斷,實際中判斷有效的并不一定是有效的(比如:客戶端取消了請求,服務端是不知道的),但是一般判斷為無效的,那肯定是無效了。

DeferredResult 處理過程如下:

  • 控制器返回一個 DeferredResult 并將其保存在可以訪問的內存隊列或列表中。
  • Spring MVC 調用 request.startAsync() 。
  • 同時,DispatcherServlet 和所有配置的過濾器退出請求處理線程,但響應保持打開狀態。
  • 應用程序從某個線程設置 DeferredResult ,Spring MVC 將請求分派回 Servlet 容器。
  • 再次調用 DispatcherServlet ,并使用異步生成的返回值繼續處理。

提供一個線程池

異步請求,不會一直占用請求的主線程(tomcat容器中處理請求的線程),而是通過一個其他的線程來處理異步任務。也正是如此,在相同的最大請求數配置下,異步請求由于迅速的釋放了主線程,所以才能提高吞吐量。

這里提到一個其他線程,那么這個其他線程我們一般都不適用默認的,都是根據自身情況提供一個線程池供異步請求使用:(我給的參數都是測試用的,實際中不可照搬)。

@Bean("mvcAsyncTaskExecutor")
public AsyncTaskExecutor asyncTaskExecutor() {
    ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
    // 線程池維護線程的最少數量
    // asyncServiceExecutor.setCorePoolSize(Runtime.getRuntime().availableProcessors() + 1);
    executor.setCorePoolSize(5);
    // 線程池維護線程的最大數量
    executor.setMaxPoolSize(10);
    // 線程池所使用的緩沖隊列
    executor.setQueueCapacity(10);
    //   asyncServiceExecutor.prefersShortLivedTasks();
    executor.setThreadNamePrefix("fyk-mvcAsyncTask-Thread-");
    asyncServiceExecutor.setBeanName("TaskId" + taskId);
    //  asyncServiceExecutor.setKeepAliveSeconds(20);
    //調用者執行
    //   asyncServiceExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
    executor.setRejectedExecutionHandler(new ThreadPoolExecutor.DiscardPolicy());
    // 線程全部結束才關閉線程池
    executor.setWaitForTasksToCompleteOnShutdown(true);
    // 如果超過60s還沒有銷毀就強制銷毀,以確保應用最后能夠被關閉,而不是阻塞住
    executor.setAwaitTerminationSeconds(30);
    executor.initialize();

    return executor;
}

把這個線程池配置設置到異步請求配置中:

@Configuration
public class FykWebMvcConfigurer implements WebMvcConfigurer {

    @Autowired
    @Qualifier("mvcAsyncTaskExecutor")
    private AsyncTaskExecutor asyncTaskExecutor;

    @Override
    public void configureAsyncSupport(AsyncSupportConfigurer configurer) {
        //異步操作的超時時間,值為0或者更小,表示永不超時
        configurer.setDefaultTimeout(60001);
        configurer.setTaskExecutor(asyncTaskExecutor);
    }
}

什么時候使用異步請求

異步請求能提高吞吐量,這個是建立在相同配置(這里的配置指的是:最大連接數、最大工作線程數)的情況下。因此并不是說任何接口都可以使用異步請求。比如:一個請求是進行大量的計算(總之就是在處理這個請求的業務方法時CPU是沒有休息的),這種情況使用異步請求就沒有多大意義了,因為這時的異步請求只是把一個任務從tomcat的工作線程搬到了另一個線程罷了。

直接調大最大工作線程數配置也能到達要求。所以,真正使用異步請求的場景應該是該請求的業務代碼中,大量的時間CPU是休息的(比如:在業務代碼中請求其他系統的接口,在其他系統響應之前,CPU是阻塞等待的),這個時候使用異步請求,就可以釋放tomcat的工作線程,讓釋放的工作線程可以處理其他的請求,從而提高吞吐量。

由于異步請求增加了更多的線程切換(同步請求是同一個工作線程一直處理),所以理論上會增加接口的耗時。但,這個耗時很短很短。

責任編輯:武曉燕 來源: 碼猿技術專欄
相關推薦

2024-09-12 15:24:29

2023-02-09 08:57:11

Callable異步java

2025-07-08 09:33:08

2025-05-23 08:37:26

2025-07-18 09:40:44

2025-04-16 08:25:00

2024-06-28 09:39:58

2021-12-26 00:03:27

響應式編程異步

2023-11-07 15:11:46

Kafka技巧

2023-08-03 14:18:29

Rust阻塞函數

2025-03-28 01:03:46

高并發技術異步

2022-11-11 10:13:06

數據庫內存Milvus

2025-06-05 03:00:00

Spring異步接口

2024-05-23 16:41:40

2013-04-19 09:45:20

AMPLabHadoopHDFS

2024-09-14 11:31:27

@AsyncSpring異步

2024-01-19 13:42:00

模型訓練

2019-08-20 00:20:47

TCPHOL吞吐量

2013-04-25 10:38:40

思科存儲交換機

2024-06-06 16:15:00

點贊
收藏

51CTO技術棧公眾號

国产在线看一区| 精品国产123区| 亚洲一二三专区| 久久精品国产第一区二区三区最新章节| 亚洲乱码国产乱码精品| 999国产精品视频| 亚洲精品国产福利| www.成人黄色| 中文一区一区三区高中清不卡免费 | 最好看的2019年中文视频| 中文字幕av一区二区三区人妻少妇 | a天堂中文在线观看| 在线视频免费在线观看一区二区| 尤物tv国产一区| 在线观看免费视频国产| 高清亚洲高清| 狠狠久久亚洲欧美专区| 2021国产视频| 91社区在线观看播放| 成人夜色视频网站在线观看| 国产精品老女人视频| 国产真实乱人偷精品视频| 成人vr资源| 亚洲精品不卡在线| 欧美又黄又嫩大片a级| 成人va天堂| 婷婷六月综合亚洲| 日韩免费在线观看av| 永久av在线| 99热这里都是精品| 国产91视觉| 国产美女自慰在线观看| 人人精品人人爱| 1769国内精品视频在线播放| 久久免费精彩视频| 亚洲精品一二三区区别| 中文字幕亚洲图片| 欧美特级黄色录像| 亚洲丁香日韩| 日韩大陆欧美高清视频区| 国产精品无码自拍| 99久久99九九99九九九| 欧美剧情片在线观看| av无码精品一区二区三区| 日本乱码一区二区三区不卡| 亚洲国产另类精品专区| 日韩精品在线中文字幕| 黄页网站在线| 亚洲一区在线看| 亚洲一区二区精品在线| 淫片在线观看| 成人欧美一区二区三区| 中文字幕乱码免费| 香蕉久久aⅴ一区二区三区| **欧美大码日韩| 自拍亚洲欧美老师丝袜| 思思99re6国产在线播放| 欧美激情一区三区| 亚洲欧美国产一区二区| 日本天堂在线观看| 亚洲日本韩国一区| 最新av网址在线观看| 2024最新电影免费在线观看| 夜夜嗨av一区二区三区中文字幕| 99在线观看视频免费| av漫画网站在线观看| 午夜精品久久久久久| 六月丁香激情网| 我爱我色成人网| 欧美色欧美亚洲另类二区| 伊人网在线综合| 欧美视频三区| 亚洲国产毛片完整版| 少妇精品一区二区三区| 日韩电影免费在线观看| 久久在线精品视频| 国产一级特黄视频| 午夜一区不卡| 国产在线播放不卡| 成人午夜福利视频| 久久色在线观看| 一本久久a久久精品vr综合 | 亚洲私人黄色宅男| 国产成人永久免费视频| 欧美人体一区二区三区| 3atv一区二区三区| 熟妇人妻久久中文字幕| 成人一区不卡| 欧美激情精品久久久| 超碰超碰超碰超碰| 国产一区二区三区在线看麻豆| 国产精品swag| 草碰在线视频| 亚洲一级二级三级| 亚洲一区二区三区四区五区xx| 国产激情一区| 亚洲香蕉在线观看| 强乱中文字幕av一区乱码| 性欧美videos另类喷潮| 亚洲最大福利视频| 美丽的姑娘在线观看免费动漫| 亚洲欧美日本韩国| 免费午夜视频在线观看| 精品999日本久久久影院| 日韩精品在线第一页| 四虎884aa成人精品| 亚洲一卡久久| 成人动漫视频在线观看完整版| 国产综合视频一区二区三区免费| 亚洲狠狠爱一区二区三区| 91制片厂毛片| 欧美18免费视频| 欧美成aaa人片免费看| 亚洲第一网站在线观看| 成人午夜激情在线| 一区二区免费在线观看| 成人黄色免费短视频| 欧美videossexotv100| 免费成人深夜蜜桃视频| 久久成人精品| 九色91在线视频| 青青草视频在线免费直播| 精品视频在线免费观看| 男人操女人动态图| 日韩一级不卡| 丁香婷婷久久久综合精品国产| 巨大荫蒂视频欧美大片| 欧美综合天天夜夜久久| 中文字幕国产综合| 在线亚洲观看| 久久99精品国产99久久| 国产美女福利在线观看| 日韩色视频在线观看| 亚洲二区在线播放| 精品亚洲免费视频| 性刺激综合网| 992tv国产精品成人影院| 亚洲欧美日韩综合| 在线观看 亚洲| 久久婷婷综合激情| 可以在线看的黄色网址| 亚洲电影一级片| 日本在线观看天堂男亚洲| 视频福利在线| 欧美性高潮床叫视频| 亚洲av无码一区二区二三区| 一本综合精品| 麻豆成人在线播放| 456亚洲精品成人影院| 国产一区二区三区视频| 中文字幕免费观看视频| 欧美国产欧美亚州国产日韩mv天天看完整| 国产精品97在线| 欧洲专线二区三区| 国产精品伦子伦免费视频| 午夜视频在线看| 91麻豆精品国产无毒不卡在线观看| 日本成人免费在线观看| 国产综合久久久久久鬼色 | 亚洲一区二区三区xxx视频| 91麻豆一二三四在线| 日韩欧美一级二级三级久久久| 唐朝av高清盛宴| 成人精品视频一区二区三区尤物| 久久久久免费看黄a片app| 婷婷精品在线观看| 国产精品99久久99久久久二8| 精品999视频| 9191国产精品| 久久久久噜噜噜亚洲熟女综合| 成人白浆超碰人人人人| 男女曰b免费视频| 91亚洲国产高清| 国产精品久久久久久久久久久久午夜片| gogo久久| 中文字幕精品视频| 亚洲h视频在线观看| 欧美性极品xxxx做受| 美女av免费看| 成人h动漫精品| www.日日操| 欧美日韩免费| 欧美日韩亚洲综合一区二区三区激情在线| 国产精品久久久久久妇女| 欧美精品少妇videofree| 四虎精品在线| 777亚洲妇女| 久久一区二区三区视频| 国产精品传媒视频| 国产高清自拍视频| 国产乱淫av一区二区三区| 国产精品无码一区二区在线| 日韩www.| 蜜桃av噜噜一区二区三| 婷婷久久免费视频| 91超碰caoporn97人人| 在线观看精品一区二区三区| 欧美精品一区在线观看| 国产一区二区女内射| 天天综合网 天天综合色| 一二三四国产精品| 99久久国产综合精品麻豆| 中文字幕亚洲影院| 久久婷婷麻豆| 日韩国产一级片| 91精品国产乱码久久久久久久| 欧美视频观看一区| 网站一区二区| 91精品国产综合久久男男| 成人影院入口| 国内精品一区二区三区| 污污影院在线观看| 色综合亚洲精品激情狠狠| 飘雪影院手机免费高清版在线观看| 日韩网站在线看片你懂的| 精品乱码一区内射人妻无码| 五月天丁香久久| 国产亚洲精品码| 亚洲男人的天堂一区二区| 欧美激情视频二区| 久久久久亚洲综合| 伦理片一区二区| 国产 日韩 欧美大片| 日韩av一卡二卡三卡| 免费精品视频最新在线| 免费观看成人网| 国产亚洲在线| 波多野结衣乳巨码无在线| 黄色亚洲免费| 美女av免费观看| 欧美在线日韩| 超碰10000| 欧美黄色一区| 日韩久久久久久久久久久久| 艳女tv在线观看国产一区| 亚洲欧美国产不卡| 日韩精品午夜| 亚洲精品8mav| 99久久.com| 男插女免费视频| 亚洲成人一区| 好吊色视频988gao在线观看| 在线中文字幕第一区| 国产人妻互换一区二区| 一个色综合网| 国产精品va在线观看无码| 欧美精品综合| 免费网站在线观看视频| 一区三区视频| 成年人午夜免费视频| 亚洲免费播放| 欧美三级午夜理伦三级| 日韩激情一区二区| 中文字幕av专区| 国产一区欧美日韩| 国产成人av片| 99精品国产热久久91蜜凸| www.色多多| 久久久精品影视| 久久精品在线观看视频| 亚洲免费资源在线播放| 青青草手机视频在线观看| 亚洲午夜激情网站| av黄色在线播放| 欧美吻胸吃奶大尺度电影| 91在线公开视频| 日韩欧美亚洲国产精品字幕久久久 | 日韩一区二区三区视频在线| 亚洲h视频在线观看| 亚洲国产日韩精品在线| 九色在线免费| 久久久精品国产亚洲| 成人超碰在线| 国产97人人超碰caoprom| 欧美韩国日本| 国产精品免费一区二区三区| 欧美人妖在线| 艳母动漫在线免费观看| 亚洲经典三级| www.激情小说.com| 国产成人啪免费观看软件| 国产艳俗歌舞表演hd| 亚洲欧洲成人av每日更新| 日韩精品一区二区在线播放 | 蜜桃a∨噜噜一区二区三区| 亚洲一区二区在线看| 亚洲视频一二| 爱情岛论坛亚洲首页入口章节| 国产91精品在线观看| 日韩女同一区二区三区| 一区二区三区自拍| 天堂网一区二区| 精品人在线二区三区| 国产理论电影在线观看| 欧美大片大片在线播放| 国产精品伦理| 成人黄色片视频网站| 精品一区二区三区中文字幕老牛| 国产玉足脚交久久欧美| 激情图区综合网| 美女洗澡无遮挡| 亚洲综合色区另类av| 亚洲一级视频在线观看| 日韩精品久久久久久福利| av在线官网| 国产精品高清在线| 日韩黄色网络| 日本福利视频一区| 激情综合一区二区三区| 欧美大波大乳巨大乳| 亚洲成a人片综合在线| 国产免费av观看| 爽爽爽爽爽爽爽成人免费观看| 国产伦理精品| 国产高清在线一区二区| 久久久久久久久久久妇女| 激情婷婷综合网| 99视频热这里只有精品免费| 久久久久久久久艹| 欧美日本免费一区二区三区| 国产中文字幕在线播放| 欧美亚洲伦理www| 大香伊人久久精品一区二区| 99亚洲国产精品| 韩日精品视频一区| 老司机精品免费视频| 欧美在线免费观看视频| 青青草在线视频免费观看| 91精品国产91久久久久久不卡 | 精品国内二区三区| 一二三四区在线观看| 91在线精品视频| 婷婷综合亚洲| 不卡的av中文字幕| 国产精品久久三| 中文字幕视频一区二区| 一级做a爰片久久毛片美女图片| 韩国成人漫画| 欧洲一区二区在线| 久久久久久夜| 制服 丝袜 综合 日韩 欧美| 色综合av在线| 成人高清网站| 国产在线高清精品| 中文字幕一区二区三区在线视频| 制服丝袜中文字幕第一页 | 日韩精品中文字幕久久臀| 成人三级高清视频在线看| 国产亚洲福利社区| 在线亚洲自拍| 最新中文字幕视频| 在线观看欧美精品| 97视频在线观看网站| 国产在线视频91| 午夜日本精品| 7788色淫网站小说| 色呦呦一区二区三区| www.成人.com| 91久久精品一区二区别| 好看不卡的中文字幕| av无码一区二区三区| 91黄色免费网站| 黄网站免费在线播放| 国产精品xxx在线观看www| 国产日韩欧美三区| 我想看黄色大片| 91精品欧美综合在线观看最新| 日韩三级电影视频| 久久日韩精品| 美腿丝袜亚洲三区| 欧美激情一区二区视频| 日韩精品亚洲元码| 亚洲精品成a人ⅴ香蕉片| 真人做人试看60分钟免费| 菠萝蜜视频在线观看一区| 成人公开免费视频| 久热精品视频在线| 久久电影在线| 天天影视色综合| 亚洲va欧美va人人爽| yes4444视频在线观看| 91国产在线播放| 校园春色综合网| 国产性xxxx| 亚洲欧美在线一区二区| 国产一区二区三区国产精品| 久久久999免费视频| 国产精品久99| 亚洲欧美日韩综合在线| 国产日韩欧美黄色| 亚洲女同同性videoxma| 婷婷激情四射网| 日韩久久免费视频| 久久久久毛片免费观看| 97超碰青青草| 亚洲一区影音先锋| 欧美jizz18hd性欧美| 女女同性女同一区二区三区91| 国内精品写真在线观看| 成人小视频在线播放|