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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm 换行_pycharm回车不能换行

    pycharm 换行_pycharm回车不能换行python脚本有时一行代码写的非常长,一个屏幕塞不下,左右拉动滚动条视觉不友好。第一种方法:python里有换行标识”\”,如jfdb=spark.read.format(“jdbc”).option(“driver”,mysql_driver).option(“url”,mysql_url).option(“dbtable”,”xxxxxxxxxxxxxxxxxxxxxxxx”).option(“user”,mysql_acount).option(“password”,mysql_pa

    2022年8月26日
    6
  • oracle设置用户密码永不过期_oracle密码设置无限期

    oracle设置用户密码永不过期_oracle密码设置无限期1、查看用户的proifle是哪个,一般是default:sql>SELECTusername,PROFILEFROMdba_users;2、查看指定概要文件(如default)的密码有效期设置:sql>SELECT*FROMdba_profilessWHEREs.profile=’DEFAULT’ANDresource_name=’PASSWORD_LIFE_TIME’;3、将密码有效期由默认的180天修改成“无限制”:sql>ALTERPROF

    2022年7月28日
    42
  • Effective C++:条款28:避免返回 handles 指向对象内部成员

    Effective C++:条款28:避免返回 handles 指向对象内部成员

    2021年12月16日
    97
  • 开源微服务编排框架:Netflix Conductor「建议收藏」

    开源微服务编排框架:Netflix Conductor「建议收藏」简介:本文主要介绍netflixconductor的基本概念和主要运行机制。​作者|夜阳来源|阿里技术公众号本文主要介绍netflixconductor的基本概念和主要运行机制。

    2022年7月2日
    29
  • Unity3D | 经典小游戏Pacman

    Unity3D | 经典小游戏Pacman❥你的关注是博主坚持创作的伟大动力❥☀️项目效果展示目录☀️项目概况⭐️整体布局⭐️地图介绍⭐️玩法介绍⭐️相关知识⭐️版本说明☀️项目源码❀玩家的移动(PacmanMove.cs)❀糖豆设计(Pacdot.cs)❀敌方人机的移动(GhostMove)

    2022年5月18日
    51
  • Android游戏引擎选择[通俗易懂]

    Android游戏引擎选择[通俗易懂]Android游戏引擎选择今天在博客园看到一篇关于android游戏引擎的选择文章,特转载以便日后了解1.Ronkon(网站地址:http://www.ronkonandroid.com)如果不是想帮助作者解决一大堆兼容性问题的话还是不要使用这个引擎,我在上面浪费了1天半,就只是为了把实例程序跑起来。开始还以为是我水平菜,结果一堆人没跑起来,和我一样都是黑屏。虽然它文档做得好但我还是放弃了,本来Android平台兼容性就是老大难,在来个半吊子的引擎我可没本事搞定。2.AndEngine(网站地址:ht

    2022年9月18日
    5

发表回复

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

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