日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

詳解SpringBoot 應用如何提高服務吞吐量

瀏覽:196日期:2023-05-07 13:55:43

意外和明天不知道哪個先來。沒有危機是最大的危機,滿足現狀是最大的陷阱。

背景

生產環境偶爾會有一些慢請求導致系統性能下降,吞吐量下降,下面介紹幾種優化建議。

方案

1、undertow替換tomcat

電子商務類型網站大多都是短請求,一般響應時間都在100ms,這時可以將web容器從tomcat替換為undertow,下面介紹下步驟:

1、增加pom配置

<dependency> <groupid> org.springframework.boot </groupid> <artifactid> spring-boot-starter-web </artifactid> <exclusions> <exclusion> <groupid>org.springframework.boot </groupid> <artifactid>spring-boot-starter-tomcat </artifactid> </exclusion> </exclusions></dependency><dependency> <groupid> org.springframework.boot </groupid> <artifactid> spring-boot-starter-undertow </artifactid></dependency>

2、增加相關配置

server: undertow: direct-buffers: true io-threads: 4 worker-threads: 160

重新啟動可以在控制臺看到容器已經切換為undertow了

2、緩存

將部分熱點數據或者靜態數據放到本地緩存或者redis中,如果有需要可以定時更新緩存數據

3、異步

在代碼過程中我們很多代碼都不需要等返回結果,也就是部分代碼是可以并行執行,這個時候可以使用異步,最簡單的方案是使用springboot提供的@Async注解,當然也可以通過線程池來實現,下面簡單介紹下異步步驟。

1、pom依賴 一般springboot引入web相關依賴就行

<dependency> <groupid> org.springframework.boot </groupid> <artifactid> spring-boot-starter-web </artifactid></dependency>

2、在啟動類中增加@EnableAsync注解

import org.springframework.boot.SpringApplication@EnableAsync@SpringBootApplicationpublic class AppApplication { public static void main(String[] args) { SpringApplication.run(AppApplication.class, args); }}

3、需要時在指定方法中增加@Async注解,如果是需要等待返回值,則demo如下

@Asyncpublic Future<String> doReturn(int i) { try { // 這個方法需要調用500毫秒 Thread.sleep(500); } catch (InterruptedException e) { e.printStackTrace(); } // 消息匯總 return new AsyncResult<String>('異步調用');}

4、如果有線程變量或者logback中的mdc,可以增加傳遞

import org.slf4j.MDC;import org.springframework.context.annotation.Configuration;import org.springframework.core.task.TaskDecorator;import org.springframework.scheduling.annotation.AsyncConfigurerSupport;import org.springframework.scheduling.annotation.EnableAsync;import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;import java.util.Map;import java.util.concurrent.Executor;/** * @Description: */@EnableAsync@Configurationpublic class AsyncConfig extends AsyncConfigurerSupport { @Override public Executor getAsyncExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setTaskDecorator(new MdcTaskDecorator()); executor.initialize(); return executor; }}class MdcTaskDecorator implements TaskDecorator { @Override public Runnable decorate(Runnable runnable) { Map<string, string> contextMap = MDC.getCopyOfContextMap(); return () - & gt; { try {MDC.setContextMap(contextMap);runnable.run(); } finally {MDC.clear(); } }; }}

5、有時候異步需要增加阻塞

import lombok.extern.slf4j.Slf4j;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;import java.util.concurrent.Executor;import java.util.concurrent.ThreadPoolExecutor;@Configuration@Slf4jpublic class TaskExecutorConfig { @Bean('localDbThreadPoolTaskExecutor') public Executor threadPoolTaskExecutor() { ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor(); taskExecutor.setCorePoolSize(5); taskExecutor.setMaxPoolSize(200); taskExecutor.setQueueCapacity(200); taskExecutor.setKeepAliveSeconds(100); taskExecutor.setThreadNamePrefix('LocalDbTaskThreadPool'); taskExecutor.setRejectedExecutionHandler((Runnable r, ThreadPoolExecutor executor) - & gt; { if (!executor.isShutdown()) {try { Thread.sleep(300); executor.getQueue().put(r);} catch (InterruptedException e) { log.error(e.toString(), e); Thread.currentThread().interrupt();} } } ); taskExecutor.initialize(); return taskExecutor; }}

4、業務拆分

可以將比較耗時或者不同的業務拆分出來提供單節點的吞吐量

5、集成消息隊列

有很多場景對數據實時性要求不那么強的,或者對業務進行業務容錯處理時可以將消息發送到kafka,然后延時消費。舉個例子,根據條件查詢指定用戶發送推送消息,這里可以時按時、按天、按月等等,這時就

詳解SpringBoot 應用如何提高服務吞吐量

到此這篇關于詳解SpringBoot 應用如何提高服務吞吐量的文章就介紹到這了,更多相關SpringBoot 提高服務吞吐量內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品1luya在线播放| 视频一区日韩精品| 国产精品麻豆成人av电影艾秋| 日韩在线观看一区二区三区| 日韩精品国产精品| 国产精品视频3p| 精品国产乱码久久久久久樱花| 精品美女久久| 色婷婷久久久| 免费久久99精品国产| 亚洲精品乱码| 欧美激情aⅴ一区二区三区 | 日本成人精品| 免费在线亚洲欧美| 中文字幕在线视频久| 欧美日韩少妇| 国产精品一级| 秋霞影视一区二区三区| 亚洲丝袜美腿一区| 久久精品二区亚洲w码 | 国产精品一区毛片| 91欧美在线| 在线亚洲免费| 国产精久久久| 香蕉国产精品| 久久精品 人人爱| 久久久久亚洲| 欧美日韩一区二区三区不卡视频 | 国产精品亚洲四区在线观看| 91欧美在线| 亚洲专区视频| 色爱综合网欧美| 视频一区二区三区在线| 欧美国产另类| 另类激情亚洲| 国产中文在线播放| 日韩一区二区三区精品视频第3页| 精品国产aⅴ| 日av在线不卡| 中文字幕在线视频网站| 日本a级不卡| 久久久久网站| 国产精品任我爽爆在线播放 | 国产在线视频欧美一区| 亚洲伊人影院| 欧美精品日日操| 国产亚洲精品美女久久| 99国产一区| 欧美片第1页| 国产伦乱精品| 在线精品视频一区| 久久中文字幕av| 精品视频在线一区二区在线| 美女精品在线| 999国产精品永久免费视频app| 国产精品网站在线看| 视频在线观看国产精品| 欧美羞羞视频| 欧美成人一二区| 色婷婷成人网| 午夜在线一区| 亚洲先锋成人| 精品理论电影在线| 国产精品色在线网站| 蜜桃视频第一区免费观看| 91精品韩国| 国内在线观看一区二区三区| 国产欧美一区| 亚洲开心激情| 午夜日韩av| 亚洲黑丝一区二区| 色黄视频在线观看| 免费一级欧美在线观看视频 | 韩国精品主播一区二区在线观看 | 免费日韩成人| 日韩国产欧美视频| 一区二区不卡| 亚洲一二三区视频| 丝袜脚交一区二区| 另类亚洲自拍| 视频一区视频二区中文字幕| 亚洲激情不卡| 伊人精品在线| 中文精品在线| 日韩视频一区二区三区在线播放免费观看| 天堂中文在线播放| 日韩一区电影| 麻豆国产在线| 久久久噜噜噜| 尤物tv在线精品| 国产网站在线| 成人自拍av| 欧美日韩精品一区二区视频| 久久激情中文| 亚洲电影在线一区二区三区| 午夜视频精品| 亚洲日本欧美| 国产精品亚洲四区在线观看| 麻豆精品视频在线| 日韩1区2区| 性欧美xxxx免费岛国不卡电影| 免费毛片在线不卡| 99视频精品| 亚州av日韩av| 国产精品日韩精品在线播放| 国产精品一区二区美女视频免费看| 国产精品一区二区精品视频观看 | 国产成人精品亚洲线观看| 最新中文字幕在线播放 | 亚洲v在线看| 亚洲一区国产| 亚洲婷婷丁香| 国产精品黄色| 欧美三区四区| 午夜久久久久| 三级久久三级久久久| 国产精品一区二区精品| 国产精选在线| 久久一区二区三区电影| 日韩影院精彩在线| 国产激情一区| 欧美/亚洲一区| 亚洲欧美在线综合| 国产精品嫩草影院在线看| 国产高清不卡| 视频一区二区三区在线| 国产色噜噜噜91在线精品| 国产一区二区亚洲| 亚洲精品99| 欧美一区在线观看视频| 国产一区二区三区视频在线| av一区二区高清| 国产亚洲一区二区三区不卡| 亚洲精品88| 日本久久二区| 天堂中文在线播放| 亚洲综合色婷婷在线观看| 麻豆久久久久久| 最新国产拍偷乱拍精品| 国产精品一区二区精品| 午夜欧美精品久久久久久久| 欧美啪啪一区| 一区二区三区四区在线看| 国产色99精品9i| 亚洲国产专区| 国产精品极品国产中出| 欧美日韩少妇| 精品日产乱码久久久久久仙踪林| 好看不卡的中文字幕| 国产精品毛片视频| 一区免费在线| 国产精品成久久久久| 亚洲精品视频一二三区| 亚洲国产福利| 国产乱码精品一区二区三区四区 | 黄色av日韩| 久久麻豆视频| 久久国产88| 婷婷成人在线| 精品国产欧美日韩| 日本在线不卡视频| 亚洲精品97| 国产精品久久久久蜜臀| 日韩黄色在线观看| 免费视频亚洲| 国产成人精品一区二区三区视频 | 久久不见久久见免费视频7| 在线亚洲国产精品网站| 亚洲美女久久精品| 国产亚洲高清在线观看| 欧美日韩国产亚洲一区| 国产中文在线播放| 久久国产生活片100| 久久亚洲国产精品一区二区| 亚洲黄色免费av| 免费看一区二区三区| 蜜桃视频一区二区| 激情六月综合| 三上悠亚国产精品一区二区三区 | 欧美午夜不卡| 午夜av不卡| 精品视频91| 国产精品手机在线播放| 日韩三级精品| 日韩一级欧洲| 亚洲精品一区二区妖精| 日本韩国欧美超级黄在线观看| 91成人在线网站| 中文字幕一区日韩精品| 亚洲综合精品| 亚洲一区二区三区四区五区午夜| 在线日韩视频| 国户精品久久久久久久久久久不卡| 国产一区2区| 麻豆精品久久| 欧美激情精品| 免费在线播放第一区高清av| 久久99久久久精品欧美| 国产欧美三级| 欧美日韩中出|