摘要:對(duì)多線(xiàn)程的支持詳解這兩天看阿里的開(kāi)發(fā)手冊(cè),到多線(xiàn)程的時(shí)候說(shuō)永遠(yuǎn)不要用這種方式來(lái)使用多線(xiàn)程。在使用線(xiàn)程池的大多數(shù)情況下都是異步非阻塞的。二配置類(lèi)配置類(lèi)代碼如下下午解讀利用來(lái)開(kāi)啟對(duì)于異步任務(wù)的支持配置類(lèi)實(shí)現(xiàn)接口,返回一個(gè)線(xiàn)程池對(duì)象。
Springboot對(duì)多線(xiàn)程的支持詳解
這兩天看阿里的JAVA開(kāi)發(fā)手冊(cè),到多線(xiàn)程的時(shí)候說(shuō)永遠(yuǎn)不要用 new Thread()這種方式來(lái)使用多線(xiàn)程。確實(shí)是這樣的,我一直在用線(xiàn)程池,到了springboot才發(fā)現(xiàn)他已經(jīng)給我們提供了很方便的線(xiàn)程池機(jī)制。一、介紹
本博客代碼托管在github上https://github.com/gxz0422042...
Spring是通過(guò)任務(wù)執(zhí)行器(TaskExecutor)來(lái)實(shí)現(xiàn)多線(xiàn)程和并發(fā)編程,使用ThreadPoolTaskExecutor來(lái)創(chuàng)建一個(gè)基于線(xiàn)城池的TaskExecutor。在使用線(xiàn)程池的大多數(shù)情況下都是異步非阻塞的。我們配置注解@EnableAsync可以開(kāi)啟異步任務(wù)。然后在實(shí)際執(zhí)行的方法上配置注解@Async上聲明是異步任務(wù)。
二、配置類(lèi)配置類(lèi)代碼如下:
package com.spartajet.springbootlearn.thread; import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.annotation.AsyncConfigurer; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; import java.util.concurrent.Executor; /** * @description * @create 2017-02-22 下午11:53 * @email gxz04220427@163.com */ @Configuration @EnableAsync public class ThreadConfig implements AsyncConfigurer { /** * The {@link Executor} instance to be used when processing async * method invocations. */ @Override public Executor getAsyncExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(5); executor.setMaxPoolSize(15); executor.setQueueCapacity(25); executor.initialize(); return executor; } /** * The {@link AsyncUncaughtExceptionHandler} instance to be used * when an exception is thrown during an asynchronous method execution * with {@code void} return type. */ @Override public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() { return null; } }
解讀:
利用EnableAsync來(lái)開(kāi)啟Springboot對(duì)于異步任務(wù)的支持
配置類(lèi)實(shí)現(xiàn)接口AsyncConfigurator,返回一個(gè)ThreadPoolTaskExecutor線(xiàn)程池對(duì)象。
三、任務(wù)執(zhí)行任務(wù)執(zhí)行代碼:
package com.spartajet.springbootlearn.thread; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; /** * @description * @create 2017-02-23 上午12:00 * @email gxz04220427@163.com */ @Service public class AsyncTaskService { @Async public void executeAsyncTask(int i) { System.out.println("線(xiàn)程" + Thread.currentThread().getName() + " 執(zhí)行異步任務(wù):" + i); } }
代碼解讀:
通過(guò)@Async注解表明該方法是異步方法,如果注解在類(lèi)上,那表明這個(gè)類(lèi)里面的所有方法都是異步的。
四、測(cè)試代碼package com.spartajet.springbootlearn; import com.spartajet.springbootlearn.thread.AsyncTaskService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith (SpringRunner.class) @SpringBootTest public class SpringbootLearnApplicationTests { @Autowired private AsyncTaskService asyncTaskService; @Test public void contextLoads() { } @Test public void threadTest() { for (int i = 0; i < 20; i++) { asyncTaskService.executeAsyncTask(i); } } }
測(cè)試結(jié)果:
線(xiàn)程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):3 線(xiàn)程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):1 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):0 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):7 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):8 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):9 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):10 線(xiàn)程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):4 線(xiàn)程ThreadPoolTaskExecutor-3 執(zhí)行異步任務(wù):2 線(xiàn)程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):12 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):11 線(xiàn)程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):6 線(xiàn)程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):5 線(xiàn)程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):16 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):15 線(xiàn)程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):14 線(xiàn)程ThreadPoolTaskExecutor-3 執(zhí)行異步任務(wù):13 線(xiàn)程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):19 線(xiàn)程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):18 線(xiàn)程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):17
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/76485.html
摘要:線(xiàn)程切換效率低下單機(jī)核數(shù)固定,線(xiàn)程爆炸之后操作系統(tǒng)頻繁進(jìn)行線(xiàn)程切換,應(yīng)用性能急劇下降。線(xiàn)程切換效率低下由于模型中線(xiàn)程數(shù)量大大降低,線(xiàn)程切換效率因此也大幅度提高。將兩個(gè)線(xiàn)程優(yōu)雅地關(guān)閉。創(chuàng)建管道的子處理器,用于處理。 Netty+SpringBoot+FastDFS+Html5實(shí)現(xiàn)聊天App,項(xiàng)目介紹:https://segmentfault.com/a/11... Netty+Sprin...
摘要:線(xiàn)程切換效率低下單機(jī)核數(shù)固定,線(xiàn)程爆炸之后操作系統(tǒng)頻繁進(jìn)行線(xiàn)程切換,應(yīng)用性能急劇下降。線(xiàn)程切換效率低下由于模型中線(xiàn)程數(shù)量大大降低,線(xiàn)程切換效率因此也大幅度提高。將兩個(gè)線(xiàn)程優(yōu)雅地關(guān)閉。創(chuàng)建管道的子處理器,用于處理。 Netty+SpringBoot+FastDFS+Html5實(shí)現(xiàn)聊天App,項(xiàng)目介紹:https://segmentfault.com/a/11... Netty+Sprin...
摘要:多線(xiàn)程編程這篇文章分析了多線(xiàn)程的優(yōu)缺點(diǎn),如何創(chuàng)建多線(xiàn)程,分享了線(xiàn)程安全和線(xiàn)程通信線(xiàn)程池等等一些知識(shí)。 中間件技術(shù)入門(mén)教程 中間件技術(shù)入門(mén)教程,本博客介紹了 ESB、MQ、JMS 的一些知識(shí)... SpringBoot 多數(shù)據(jù)源 SpringBoot 使用主從數(shù)據(jù)源 簡(jiǎn)易的后臺(tái)管理權(quán)限設(shè)計(jì) 從零開(kāi)始搭建自己權(quán)限管理框架 Docker 多步構(gòu)建更小的 Java 鏡像 Docker Jav...
摘要:前提好幾周沒(méi)更新博客了,對(duì)不斷支持我博客的童鞋們說(shuō)聲抱歉了。熟悉我的人都知道我寫(xiě)博客的時(shí)間比較早,而且堅(jiān)持的時(shí)間也比較久,一直到現(xiàn)在也是一直保持著更新?tīng)顟B(tài)。 showImg(https://segmentfault.com/img/remote/1460000014076586?w=1920&h=1080); 前提 好幾周沒(méi)更新博客了,對(duì)不斷支持我博客的童鞋們說(shuō)聲:抱歉了!。自己這段時(shí)...
閱讀 3782·2023-04-26 00:16
閱讀 1416·2021-11-25 09:43
閱讀 3896·2021-11-23 09:51
閱讀 3026·2021-09-24 09:55
閱讀 773·2021-09-22 15:45
閱讀 1452·2021-07-30 15:30
閱讀 3121·2019-08-30 14:04
閱讀 2343·2019-08-26 13:46