欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Spring异步

程序员文章站 2022-05-13 21:07:03
...

1.1 xml配置

<task:annotation-driven executor="asyncExecutor" />

<task:executor id="asyncExecutor" pool-size="100-10000" queue-capacity="10"/>

1.2 java配置

@Configuration  
@EnableAsync  //开启异步
public class SpringConfig {  
    private int corePoolSize = 10;  
    private int maxPoolSize = 200;  
    private int queueCapacity = 10;  

     private String ThreadNamePrefix = "MyLogExecutor-";  

    @Bean("asyncService1") 
    public Executor logExecutor() {  
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();  
        executor.setCorePoolSize(corePoolSize);  
        executor.setMaxPoolSize(maxPoolSize);  
        executor.setQueueCapacity(queueCapacity);  
        executor.setThreadNamePrefix(ThreadNamePrefix);  
        executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());  
        executor.initialize();  
        return executor;  
    }  
} 

@Component
@Async("asyncService1") //当调用改方法时,会异步调用和@Bean中参数对应
public class AsyncService {
	public void testAsync() {
	    System.out.println("begin..开始调用");
	    try {
	    	Thread.sleep(10000);
	    } catch (InterruptedException e) {
	    	System.out.println("睡眠");
    	}
    	System.out.println("end...结束调用");
    }
}

1.3 配置参数详解:

  1. id:当配置多个executor时,被@Async(“id”)指定使用;也被作为线程名的前缀。
  2. core-size:最小的线程数,缺省:1(该线程会一直存在)core-size:最小的线程数,缺省:1(该线程会一直存在)
  3. max-size:最大的线程数,缺省:Integer.MAX_VALUE(当线程数大于core-size+queue-capacity会创建最大线程,keep-alive设置该线程会被结束掉)max-size:最大的线程数,缺省:Integer.MAX_VALUE(当线程数大于core-size+queue-capacity会创建最大线程,keep-alive设置该线程会被结束掉)
  4. queue-capacity:当最小的线程数已经被占用满后,新的任务会被放进queue里面,当这个queue的capacity也被占满之后,pool里面会创建新线程处理这个任务,直到总线程数达到了maxsize,这时系统会拒绝这个任务并抛出TaskRejectedException异常(缺省配置的情况下,可以通过rejection-policy来决定如何处理这种情况)。缺省值为:Integer.MAX_VALUEqueue-capacity:当最小的线程数已经被占用满后,新的任务会被放进queue里面,当这个queue的capacity也被占满之后,pool里面会创建新线程处理这个任务,直到总线程数达到了maxsize,这时系统会拒绝这个任务并抛出TaskRejectedException异常(缺省配置的情况下,可以通过rejection-policy来决定如何处理这种情况)。缺省值为:Integer.MAX_VALUE
  5. keep-alive:超过coresize的那些线程,任务完成后,再经过这个时长(秒)会被结束掉keep-alive:超过coresize的那些线程,任务完成后,再经过这个时长(秒)会被结束掉
  6. rejection-policy:当pool已经达到max size的时候,如何处理新任务rejection-policy:当pool已经达到max size的时候,如何处理新任务
    6.1. ABORT(缺省):抛出TaskRejectedException异常,然后不执行6.1. ABORT(缺省):抛出TaskRejectedException异常,然后不执行
    6.2. DISCARD:不执行,也不抛出异常
    6.3. DISCARD_OLDEST:丢弃queue中最旧的那个任务(会抛弃队列中对开式进入的)
    6.4. CALLER_RUNS:不在新线程中执行任务,而是有调用者所在的线程来执行(会阻塞,等待所有core-size,queue-capacity,max-size执)
相关标签: spring async