线程池配置

package com.hikvision.ostore.commons.config;

import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.concurrent.*;

/**
 * @ClassName AsyncThreadPoolConfiguration
 * @Description 线程池配置
 * @Date 2022/3/28 17:27
 * @Version 1.0
 */
@Slf4j
@Configuration
public class AsyncThreadPoolConfiguration {
    @Value("${threadPool.poolSize:16}")
    private int poolSize;

    @Value("${threadPool.maximumPoolSize:64}")
    private int maximumPoolSize;

    @Value("${threadPool.queueSize:300000}")
    private int queueSize;

    @Value("${threadPool.keepAliveTime:10}")
    private long keepAliveTime;

    @Value("${threadPool.orderPoolSize:1}")
    private int orderPoolSize;

    /**
     * 订单的线程池
     *
     * @return
     */
    @Bean(name = "orderTaskExecutor")
    public ThreadPoolExecutor orderTaskExecutor() {
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(orderPoolSize, maximumPoolSize,
                keepAliveTime, TimeUnit.MINUTES,
                new LinkedBlockingQueue<>(queueSize),
                new ThreadPoolExecutor.CallerRunsPolicy());
        log.info("order task thread pool : poolSize= [{}] , maximumPoolSize = [{}] , queueSize = [{}] , keepAliveTime = [{}]"
                , poolSize, maximumPoolSize, queueSize, keepAliveTime);
        return threadPoolExecutor;
    }

    /**
     * 物料的线程池
     *
     * @return
     */
    @Bean(name = "materialTaskExecutor")
    public ThreadPoolExecutor materialTaskExecutor() {
        ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(poolSize, maximumPoolSize,
                keepAliveTime, TimeUnit.MINUTES,
                new LinkedBlockingQueue<>(queueSize),
                new ThreadPoolExecutor.CallerRunsPolicy());
        log.info("material task thread pool : poolSize= [{}] , maximumPoolSize = [{}] , queueSize = [{}] , keepAliveTime = [{}]"
                , poolSize, maximumPoolSize, queueSize, keepAliveTime);
        return threadPoolExecutor;
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值