java-如何在TaskExecutionAutoConfiguration旁边创建其他TaskExecutor?

本文探讨了在Spring框架中同时使用默认ThreadPoolTaskExecutor与自定义ThreadPoolExecutor的方法。通过@AutoConfigureAfter注解,确保自定义执行器在TaskExecutionAutoConfiguration之后加载,实现两者共存。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我希望spring从TaskExecutionAutoConfiguration加载默认的ThreadPoolTask​​Executor.尽管我想为一些明确的副任务提供可能的其他执行程序:

 

 

@Bean
public ThreadPoolExecutor myRequestPool() {
    return (ThreadPoolExecutor) Executors.newFixedThreadPool(10);
}

问题:在上面添加bean时,将不再执行TaskExecutionAutoConfiguration,并且不会初始化spring-default执行器,因为@ConditionalOnMissingBean(Executor.class)不再匹配:

 

package org.springframework.boot.autoconfigure.task;

public class TaskExecutionAutoConfiguration {

    @Lazy
    @Bean(name = APPLICATION_TASK_EXECUTOR_BEAN_NAME)
    @ConditionalOnMissingBean(Executor.class)
    public ThreadPoolTaskExecutor applicationTaskExecutor(TaskExecutorBuilder builder) {
        return builder.build();
    }

问题:我如何仍让Spring创建两个bean?

最佳答案

仅当在处理自动配置时不存在其他执行器bean(由于@ConditionalOnMissingBean(Executor.class))时,才会创建TaskExecutionAutoConfiguration中的执行器bean.因此,为了创建我们的执行程序和TaskExecutionAutoConfiguration中定义的执行程序,我们需要确保在TaskExecutionAutoConfiguration之后处理了我们的bean.

 

根据docs,如果我们使bean成为自动配置的候选对象(这需要在META-INF / spring.factories中添加@Configuration类),则可以使用@AutoConfigureAfter将其配置为在TaskExecutionAutoConfiguration之后进行处理:

 

package foo.bar.baz.qux;

@Configuration
@AutoConfigureAfter(TaskExecutionAutoConfiguration.class)
public class Config {
    @Bean
    public ThreadPoolExecutor myRequestPool() {
        return (ThreadPoolExecutor) Executors.newFixedThreadPool(10);
    }
}

然后创建META-INF / spring.factories,其中包含:

 

org.springframework.boot.autoconfigure.EnableAutoConfiguration=\
  foo.bar.baz.qux.Config
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值