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

SpringBoot 異步接口實(shí)現(xiàn):提高系統(tǒng)的吞吐量

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

前言

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

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

在springboot應(yīng)用中,可以有4種方式實(shí)現(xiàn)異步接口(至于ResponseBodyEmitter、SseEmitter、StreamingResponseBody,不在本文介紹內(nèi),之后新寫文章介紹):

  • AsyncContext
  • Callable
  • WebAsyncTask
  • DeferredResult

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

特別說明:服務(wù)端的異步或同步對于客戶端而言是不可見的。不會因?yàn)榉?wù)端使用了異步,接口的結(jié)果就和同步不一樣了。另外,對于單個請求而言,使用異步接口會導(dǎo)致響應(yīng)時間比同步大,但不特別明顯。具體后文分析。

基于Callable實(shí)現(xiàn)

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

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

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

Callable 處理過程如下:

控制器返回一個 Callable 。

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

Callable默認(rèn)使用SimpleAsyncTaskExecutor類來執(zhí)行,這個類非常簡單而且沒有重用線程。在實(shí)踐中,需要使用AsyncTaskExecutor類來對線程進(jìn)行配置。

基于WebAsyncTask實(shí)現(xiàn)

Spring提供的WebAsyncTask是對Callable的包裝,提供了更強(qiáng)大的功能,比如:處理超時回調(diào)、錯誤回調(diào)、完成回調(diào)等。本質(zhì)上,和Callable區(qū)別不大,但是由于它額外封裝了一些事件的回調(diào),所有,通常都使用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可以配置一個超時時間,這里配置的超時時間比全局配置的超時時間優(yōu)先級都高(會覆蓋全局配置的超時時間)。

基于DeferredResult實(shí)現(xiàn)

DeferredResult使用方式與Callable類似,但在返回結(jié)果時不一樣,它返回的時實(shí)際結(jié)果可能沒有生成,實(shí)際的結(jié)果可能會在另外的線程里面設(shè)置到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;
}

如果調(diào)用以上接口,會發(fā)現(xiàn)客戶端的請求一直是在pending狀態(tài)——等待后端響應(yīng)。這里,我簡單的將該接口返回的DeferredResult對象存放在了一個Map集合中,實(shí)際應(yīng)用中可以設(shè)計一個對象管理器來統(tǒng)一管理這些個對象。

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

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

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

其他線程修改DeferredResult的值:首先是從之前存放DeferredResult的map中拿到DeferredResult的值,然后設(shè)置它的返回值。當(dāng)執(zhí)行deferredResult.setResult之后,可以看到之前pending狀態(tài)的接口完成了響應(yīng),得到的結(jié)果,就是這里設(shè)置的值。

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

DeferredResult 處理過程如下:

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

提供一個線程池

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

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

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

    return executor;
}

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

@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);
    }
}

什么時候使用異步請求

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

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

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

責(zé)任編輯:趙寧寧 來源: 碼猿技術(shù)專欄
相關(guān)推薦

2024-09-09 14:12:38

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

響應(yīng)式編程異步

2023-11-07 15:11:46

Kafka技巧

2023-08-03 14:18:29

Rust阻塞函數(shù)

2025-03-28 01:03:46

高并發(fā)技術(shù)異步

2022-11-11 10:13:06

數(shù)據(jù)庫內(nèi)存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

模型訓(xùn)練

2019-08-20 00:20:47

TCPHOL吞吐量

2013-04-25 10:38:40

思科存儲交換機(jī)

2024-06-06 16:15:00

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

欧美亚洲国产视频| 精品成人免费观看| 黄色一级视频播放| 成人毛片在线精品国产| 亚洲欧美卡通另类91av| 中文字幕日韩电影| 国产精久久久久| 五月天av在线| 亚洲免费成人av| 欧美 日韩 国产在线| 91麻豆国产视频| 99riav国产精品| 色偷偷88888欧美精品久久久 | 欧美狂野另类xxxxoooo| 日韩一级特黄毛片| 都市激情在线视频| 成人av在线播放网址| 国产精品三级美女白浆呻吟| 国产亚洲自拍av| 日韩电影免费网站| 精品无人国产偷自产在线| 四季av一区二区三区| 伊人成综合网站| 玉米视频成人免费看| 天堂av一区二区| 天天干天天摸天天操| 国产一区二区三区久久久 | 国产无码精品在线观看| 成人影视亚洲图片在线| 亚洲国产中文字幕久久网| 亚洲一区二区三区观看| 日韩a**中文字幕| 欧美日韩免费网站| 国产精品久久久久9999爆乳| 免费黄色在线| 国产精品你懂的在线欣赏| 精品久久久久久亚洲| 国产成人精品一区二三区四区五区 | 国产又色又爽又黄的| 欧美 亚欧 日韩视频在线| 在线视频中文亚洲| 久久久久久久久久久久| 神马午夜久久| 精品亚洲一区二区三区四区五区| 自拍视频第一页| 一区二区视频| 欧美哺乳videos| 在线播放第一页| 97青娱国产盛宴精品视频| 日韩欧美中文一区| 亚欧精品在线视频| 国产精品一区二区三区www| 欧美日韩久久久一区| 性刺激的欧美三级视频| www.国产精品| 欧美片网站yy| 亚洲精品在线视频播放| 高清国产一区二区三区四区五区| 欧美日韩成人一区| 在线观看av免费观看| 在线观看欧美| 日韩精品一区二区三区在线播放| 先锋资源在线视频| 成人福利一区| 精品视频—区二区三区免费| 国产在线观看h| 成人综合一区| 欧美成人免费一级人片100| 精品一区在线观看视频| 国产一区二区三区四区老人| 97久久久免费福利网址| 天天操夜夜操视频| 日av在线不卡| 97超碰人人看人人| 色香蕉在线视频| 国产性色一区二区| 亚洲一区免费看| 伊人222成人综合网| 亚洲成av人片在线| 美女喷白浆视频| 国产精品一区免费在线| 亚洲国产精品999| av中文字幕免费观看| 五月激情久久久| 国产69精品久久久久9| 三级网站在线播放| 国内精品久久久久影院色| 国产精品亚洲不卡a| 国产51人人成人人人人爽色哟哟 | 青青操在线视频观看| 欧美精品不卡| 日本一区二区不卡| 国产视频手机在线观看| 91色婷婷久久久久合中文| 亚洲 国产 欧美一区| 国产一区久久精品| 欧美日韩一区二区免费视频| 久久精品国产露脸对白| 亚洲深夜福利在线观看| 毛片精品免费在线观看| 日日夜夜操视频| 国产成人午夜高潮毛片| 日韩影片在线播放| 爱情岛论坛亚洲品质自拍视频网站| 日本久久一区二区| 亚洲一区二区三区黄色| 日韩黄色大片网站| 91精品国产91久久久久福利| 国产精品久久婷婷| 久久精品网站免费观看| 精品无码国产一区二区三区av| 精品视频在线一区二区在线| 亚洲国产精品福利| 久久r这里只有精品| 丝袜美腿亚洲综合| 国产区日韩欧美| 99福利在线| 欧美精品xxxxbbbb| 久久中文字幕精品| 美女视频一区免费观看| 国产精品久久久久久免费观看| 日本中文字幕在线看| 91黄色激情网站| 欧美无人区码suv| 黄色在线成人| 91久久精品国产91久久性色tv| 尤物视频在线免费观看| 色老汉av一区二区三区| av黄色一级片| 国产精品v亚洲精品v日韩精品| 91精品久久久久久久久不口人| 国产原创av在线| 一本色道**综合亚洲精品蜜桃冫| 六十路息与子猛烈交尾| 亚洲人体偷拍| 国产一区二区免费在线观看| 丁香花在线电影| 日韩免费一区二区| 精品欧美一区二区久久久久| 狠狠色丁香婷婷综合久久片| 亚洲欧洲三级| 欧美男男gaygay1069| 国产一区二区三区直播精品电影| 色av性av丰满av| 久久久亚洲高清| 日本999视频| 欧美理论电影大全| 国产精品电影观看| 成人资源www网在线最新版| 一本大道综合伊人精品热热| 波多野结衣 在线| 日韩国产欧美在线视频| 日韩尤物视频| 欧美另类激情| 久久国产精品久久久久久久久久| 精品毛片一区二区三区| 亚洲综合在线五月| 91玉足脚交白嫩脚丫| 国产亚洲精品v| 欧美重口乱码一区二区| 国产综合色区在线观看| 中文字幕日韩欧美在线视频| 97精品人妻一区二区三区香蕉 | 日韩精品在线免费观看视频| 啦啦啦免费高清视频在线观看| 久久综合久久综合久久综合| 超碰在线播放91| 综合五月婷婷| 国产一区二区精品免费| 日韩新的三级电影| 国产一区二区精品丝袜| 国产视频一区二区三区四区五区| 一卡二卡三卡日韩欧美| 黄色网址在线视频| 老司机精品导航| 亚洲草草视频| 亚洲日本va| 欧洲中文字幕国产精品| 午夜在线视频| 精品盗摄一区二区三区| 波多野结衣一二区| 亚洲精品福利视频网站| 黄色录像a级片| 另类欧美日韩国产在线| 和岳每晚弄的高潮嗷嗷叫视频| 男男gay无套免费视频欧美| 成人免费在线网址| 午夜影院一区| 久久精品视频在线观看| 免费看av毛片| 欧美精品一二三| 天天爽夜夜爽夜夜爽精品| 中文字幕中文字幕在线一区| 国产黑丝一区二区| 久久成人精品无人区| 俄罗斯av网站| 一区二区三区在线| 欧美一区二区三区电影在线观看| 国产高清日韩| 日本久久91av| 在线观看电影av| 夜夜嗨av一区二区三区四区 | 亚洲精品一区中文字幕乱码| 国产老妇伦国产熟女老妇视频| 亚洲高清视频的网址| 欧美成人久久久免费播放| av动漫一区二区| 男人午夜视频在线观看| 久久中文字幕一区二区三区| 日本免费a视频| 99热国内精品| 色99中文字幕| 日韩精品福利一区二区三区| 999在线观看免费大全电视剧| av在线不卡精品| 欧美又大又硬又粗bbbbb| 欧美巨大xxxx做受沙滩| www国产精品com| 国产精品久久一区二区三区不卡| 亚洲精美色品网站| 亚洲国产精品成人久久蜜臀| 欧美日韩精品一区二区在线播放| 中文字幕第四页| 欧美日韩国产黄| 劲爆欧美第一页| 亚洲精品免费在线观看| 久久av无码精品人妻系列试探| 国产 日韩 欧美大片| 女王人厕视频2ⅴk| 九九热在线视频观看这里只有精品| 成年人在线看片| 美女网站久久| 日本三区在线观看| 久久蜜桃资源一区二区老牛| 日本精品一区二区三区四区 | 97免费中文视频在线观看| 91蜜桃在线视频| 超碰精品一区二区三区乱码| 老司机免费在线视频| 日韩小视频网址| 黄色在线免费| 免费成人高清视频| 菠萝菠萝蜜在线观看| 久久综合伊人77777蜜臀| jizzjizz在线观看| 色系列之999| 麻豆最新免费在线视频| 久久综合久久八八| 丝袜在线观看| 久久久女人电视剧免费播放下载| 超级碰碰不卡在线视频| 97视频在线观看免费| 日韩大片免费观看| 欧美一区二区.| 欧美大片免费高清观看| 国产成人中文字幕| 久久三级毛片| 91在线观看欧美日韩| 日本在线一区二区三区| 国产精品日韩一区二区三区 | 超碰一区二区| 国产精品久久久久国产a级| 欧美激情福利| 91手机在线观看| 欧美成人午夜77777| 日本高清不卡三区| 久久免费大视频| 伊人再见免费在线观看高清版| 亚洲一级特黄| 十八禁视频网站在线观看| 久久国产综合精品| 中国特级黄色片| www精品美女久久久tv| 在线观看亚洲大片短视频| 亚洲女女做受ⅹxx高潮| 国产精品自拍视频一区| 色哦色哦哦色天天综合| 91色在线播放| 亚洲国产精品久久精品怡红院| 青青视频在线观| 不卡av电影院| 久久毛片亚洲| 91在线高清视频| 亚洲人亚洲人色久| 中文字幕一区二区三区最新 | 午夜精品视频在线| 国产精品高清乱码在线观看| 亚洲aa中文字幕| 免费看日本一区二区| 欧美大片免费播放| 老**午夜毛片一区二区三区| 久久久福利影院| 久久久国产精华| 久久久久久久久久久久国产| 91高清在线观看| 老司机午夜福利视频| 深夜精品寂寞黄网站在线观看| 2021中文字幕在线| 国产日韩欧美综合| 久久精品66| 91精品国产吴梦梦| 免费成人你懂的| 精品无码在线视频| 一区二区三区精品视频| 国产一级片av| 日韩国产精品一区| 91小视频xxxx网站在线| 国产噜噜噜噜噜久久久久久久久| 欧美毛片免费观看| 欧美这里只有精品| 激情五月婷婷综合| 免费福利视频网站| 欧美性高跟鞋xxxxhd| 国产ts变态重口人妖hd| 深夜精品寂寞黄网站在线观看| 密臀av在线播放| 官网99热精品| 欧美在线视屏| gai在线观看免费高清| 久久精品人人做| 男人日女人网站| 亚洲国产欧美久久| 国产精品—色呦呦| 亚洲999一在线观看www| 久久亚洲精品中文字幕蜜潮电影| 成年人免费在线播放| www.欧美色图| 亚洲国产精品午夜在线观看| 欧美成人a视频| a级毛片免费观看在线| 91免费精品视频| 99视频精品全部免费在线视频| 无限资源日本好片| 欧美国产日韩一二三区| 免费无码国产精品| 亚洲精品视频久久| 周于希免费高清在线观看| 国产亚洲精品自在久久| 狠色狠色综合久久| av在线天堂网| 午夜国产精品一区| 五月天婷婷在线播放| 欧美一区第一页| 九热爱视频精品视频| 久久久久免费精品| 国产午夜精品美女毛片视频| 色老头一区二区| 一区二区三区天堂av| 91p九色成人| 中文字幕乱码一区二区三区| 国产中文一区二区三区| 欧美日韩国产精品综合| 欧美精品一区二区三区视频| 国产激情视频在线看| 激情伦成人综合小说| 亚洲专区免费| 国产18无套直看片| 欧美一区二区三区免费视频 | 国产成人久久精品| 国产一区二区区别| 中文字幕av不卡在线| 最新久久zyz资源站| 亚洲国产999| 97超级碰在线看视频免费在线看| 在线看成人短视频| 污视频网站观看| 一区二区三区四区五区视频在线观看 | а√天堂资源官网在线资源| 看欧美日韩国产| 久久综合综合久久综合| 午夜免费激情视频| 日韩av在线导航| 热久久久久久| 成人午夜精品久久久久久久蜜臀| 久久日韩精品一区二区五区| 亚洲网站在线免费观看| 欧美寡妇偷汉性猛交| 香蕉久久精品日日躁夜夜躁| 性欧美1819| 亚洲第一狼人社区| 国产人成在线视频| 96pao国产成视频永久免费| 国产欧美短视频| 日韩在线视频网址| 日韩精品日韩在线观看| 另类一区二区三区| 91成人在线观看喷潮教学| 日本一二三四高清不卡| 精品人妻无码一区二区| 日本久久91av| 国产一区二区三区四区三区四| 亚洲午夜久久久久久久国产| 日韩欧美在线影院| 欧美日韩五码| 久久手机在线视频| 国产精品亲子伦对白| 午夜av免费在线观看| 91探花福利精品国产自产在线| 国产精品一区毛片| 欧美精品入口蜜桃|