ThreadPoolTaskExecutor使用

ThreadPoolTaskExecutor使用使用场景:多线程

大家好,又见面了,我是你们的朋友全栈君。

使用场景:多线程消费

1.异步注解@EnableAsync配置 

2.配置线程池bean(启动类者单独配置bean),可参考本菜鸟的其他文章

3.启动消费者;生产者可以通过其他方式

4.实际业务处理,配置异步处理注解和线程池名称 @Async(“redisThread”)

步骤一:配置异步注解和线程池

@SpringBootApplication
@EnableAsync
public class ImRedisApplication {
    public static void main(String[] args) {
        SpringApplication.run(ImRedisApplication.class, args);
    }

      @Bean("redisThread")
    public ThreadPoolTaskExecutor initRedisPool(){
        ThreadPoolTaskExecutor threadPoolTaskExecutor = new ThreadPoolTaskExecutor();
        /**
         * 核心线程数
         */
        threadPoolTaskExecutor.setCorePoolSize(4);
        /**
         * 最大线程数
         */
        threadPoolTaskExecutor.setMaxPoolSize(9);
        /**
         * 存活
         */
        threadPoolTaskExecutor.setKeepAliveSeconds(10 * 60);
        /**
         * 队列容量
         */
        threadPoolTaskExecutor.setQueueCapacity(10);
        /**
         * 线程名称
         */
        threadPoolTaskExecutor.setThreadNamePrefix("redisThread" + "-");
        /**
         * 拒绝策略,关于拒绝策略可以看实现 RejectedExecutionHandler 的类,当然也可以自定义拒接策略,也就是现实RejectedExecutionHandler接口方法
         */
        threadPoolTaskExecutor.setRejectedExecutionHandler(new ThreadPoolExecutor.AbortPolicy());
        return threadPoolTaskExecutor;
    }
}

2.通过 @PostConstruct和线程启动消费者,(生产者可以使用xxl-job,MQ或者其他方式产生,基于自己的实际业务需求)

@Component
@Slf4j
public class RedisConsumerInit {

    @Autowired
    private IdConsumerService idConsumerService;

    @PostConstruct
    public void init() {
        /**
         * 初始化启动
         */
        new PoolConsumerThread().start();
    }

    class PoolConsumerThread extends Thread {
        @Override
        public void run() {

            while (true) {
                /**
                 * 从redis,MQ等拿消息
                 */
                int i = new Random().nextInt();
                try {
                    idConsumerService.execute(i);
                } catch (RejectedExecutionException e) {
                    log.error("异常了:{}", e.getMessage());
                    /**
                     * 如遇到线程池拒绝抛异常,做其他业务处理,比如继续放置到redis队列处理或者其他
                     */
                } catch (Exception e) {
                    log.error("异常了:{}", e.getMessage());
                }

                try {
                    TimeUnit.NANOSECONDS.sleep(1);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

3.具体业务处理,特别注意开启异步注解并配置线程池的bean

@Service
@Slf4j
public class IdConsumerService {


    @Async("redisThread")
    public void execute(Integer num){
        try {
            log.info("当前消费:{}", num);
            /**
             * 实际业务处理
             */

        } catch (Exception e) {
            e.printStackTrace();
        }
    }
    
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149658.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • sql error 904_mysql报2005错误

    sql error 904_mysql报2005错误mysql清除relay-log文件方法详解mysql清除relay-log文件方法详解今天在本机的mysql数据目录下发现了许多类似hostname-relay-bin.0000*的文件,该文件一般是在mysqlslave实例上存在。主要用途是记录主从同步的信息,正常情况下会自动删除的。本机未配置过master、slave,…文章白及882016-02-245754浏览量exp导出出现…

    2022年9月20日
    5
  • GridLayout上动态添加控件「建议收藏」

    GridLayout上动态添加控件「建议收藏」Android上GridLayout和java上的感觉差不多,但是在添加布局内部添加控件就不是那么容易了。 grid=(GridLayout)findViewById(R.id.grid);//获取GridLayout控件 intcount=1; for(inti=0;i<6;i++) for(intj=0;j<5;j++){ System.out.pri

    2022年6月5日
    25
  • input标签checkbox选中触发事件的方法

    input标签checkbox选中触发事件的方法目的:1.打开页面时,根据后端返回的的值isRequired,设置页面的checkbox标签的勾选状态,并给隐藏的text标签的value赋值,以便于在提交页面时把isRequired再返回给后端2.切换checkbox标签的勾选状态时,修改隐藏的text标签的value的值,勾选是1,取消勾选是0html代码:<divclass=”col-sm-8″><inputtype=”checkbox”class=”minimalpull-leftGrandpaisR.

    2025年8月10日
    3
  • matlab secant method

    matlab secant method

    2021年12月16日
    48
  • SpringMVC之ModelAndView的用法「建议收藏」

    SpringMVC之ModelAndView的用法「建议收藏」(一)使用ModelAndView类用来存储处理完后的结果数据,以及显示该数据的视图。从名字上看ModelAndView中的Model代表模型,View代表视图,这个名字就很好地解释了该类的作用。业务处理器调用模型层处理完用户请求后,把结果数据存储在该类的model属性中,把要返回的视图信息存储在该类的view属性中,然后让该ModelAndView返回该SpringMVC框架。框架通过调用配置…

    2022年7月18日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号