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();
        }
    }
    
}

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 试题库管理系统–数据库设计

    试题库管理系统–数据库设计一、概要设计1.1背景和意义目前,许多高校绝大多数课程还采用考教统一的模式来完成教学过程,这种传统的考试模式在教学到实施考试的过程带有很大的主观随意性和不规范性。另外随着各高校近年来学生规模的扩大,教学任务日益繁重,教师的工作量相应的不断增加。迫切需要计算机辅助教学系统来打破这种传统的教学模式,减轻教师的工作负担,提高教学质量。因此,本文研究设计了一个试题库管理系统,来解决和缓解高校课程

  • 谷歌学术搜索文献_谷歌学术论文翻译

    谷歌学术搜索文献_谷歌学术论文翻译谷歌学术文献信息爬取及文献下载

    2022年10月11日
  • vscode直接运行html_用vscode搭建前端环境

    vscode直接运行html_用vscode搭建前端环境1.本地新建一个空的文件夹2.点击新建一个index.html文件3.输入!4.点击第一个自动生成html模板文件5.右击html文件,在浏览器中运行

  • tcp/ip和tcp协议(路由选择协议)

    一图看完本文一、计算机网络体系结构分层计算机网络体系结构分层计算机网络体系结构分层不难看出,TCP/IP与OSI在分层模块上稍有区别。OSI参考模型注重“通信协议必要的功能是什么”,而TCP/IP则更强调“在计算机上实现协议应该开发哪种程序”。二、TCP/IP基础1.TCP/IP的具体含义从字面意义上讲,有人可能会认为…

  • 团队解散,我们该何去何从?

    团队解散,我们该何去何从?写在最前:纯属吐槽,随笔,勿喷!就在前些天,下班回家的路上,看到群信息,说:听说、听说京东裁员了~,图片来源于网络也是在上上月,也一度被传的沸沸扬扬的:阿里、京东、华为相继被曝停止社招,新闻也是满天飞舞,不管是裁员,还是停止社招,这些事情没有落在亲身经历,没有落在自己身上我们都会觉得不痛不痒,毕竟一个旁观者,永远无法感受当事人的喜怒哀乐~。俗话说:人无远虑必有近忧,假如当你遇上裁员,…

  • 分布式锁的使用场景_分布式锁的三种实现的对比

    分布式锁的使用场景_分布式锁的三种实现的对比前言对于锁大家肯定不会陌生,比如synchronized关键字和ReentrantLock可重入锁,一般我们用其在多线程环境中控制对资源的并发访问。但是随着业务的发展,分布式的概念逐渐出现在我们系统中,我们在开发的过程中经常需要进行多个系统之间的交互,于是上面的加锁方法就会失去作用。于是在分布式锁就自然而然的诞生了,接下来我们来聊一聊分布式锁实现的几种方式。分布式锁的使用场景 效率性:使用分布式锁可以避免不同节点重复相同的工作。 正确性:分布式锁可以避免破坏正确性的发生,如

发表回复

您的电子邮箱地址不会被公开。

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