springboot线程池配置

package com.sdyy.springboot.config;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import com.google.common.util.concurrent.ThreadFactoryBuilder;
/**
 * @author li
 * @ClassName TreadPoolConfig
 * @date:  2019年6月24日 下午3:06:58
 */
@Configuration
public class TreadPoolConfig {
/**
  • ArrayBlockingQueue: 由数组结构组成的有界阻塞队列。

LinkedBlockingQueue: 由链表结构组成的有界阻塞队列。

PriorityBlockingQueue: 支持优先级排序的无界阻塞队列。

DealyQueue: 使用优先级队列实现的无界阻塞队列。

SynchronousQueue: 不存储元素的阻塞队列。

LinkedTransferQueue: 由链表结构组成的无界阻塞队列。

LinkedBlockingDeque: 由链表结构组成的双向阻塞队列。
/
/
*
* 1. CallerRunsPolicy : 这个策略重试添加当前的任务,他会自动重复调用 execute() 方法,直到成功。

   2. AbortPolicy :         对拒绝任务抛弃处理,并且抛出异常。

   3. DiscardPolicy :       对拒绝任务直接无声抛弃,没有异常信息。

   4. DiscardOldestPolicy : 对拒绝任务不抛弃,而是抛弃队列里面等待最久的一个线程,然后把拒绝任务加到队列。
 */

     * 消费队列线程
     * @return
     */
    @Bean(value = "consumerQueueThreadPool")
    public ExecutorService buildConsumerQueueThreadPool(){
        ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
                .setNameFormat("consumer-queue-thread-%d").build();

        ExecutorService pool = new ThreadPoolExecutor(5, 5, 0L, TimeUnit.MILLISECONDS,
                new ArrayBlockingQueue(5),namedThreadFactory,new ThreadPoolExecutor.AbortPolicy());

        return pool ;
    }
}



@Resource(name = "consumerQueueThreadPool")
private ExecutorService consumerQueueThreadPool;

				consumerQueueThreadPool.execute(() -> {
		                System.out.println("当前正在执行线程:" + Thread.currentThread().getName());
		            });

你可能感兴趣的:(springboot线程池配置)