线程池如何动态刷新?

线程池如何动态刷新?

1、 动态池注册

起初预定义N个默认的动态线程池【对应N种业务场景】。通过@Configuration + @Bean 的方式配置多个动态池默认实例Bean。

在 WebApplicationContext 初始化后通过实现org.springframework.beans.factory.config.BeanPostProcessor 接口的类将动态池的实例通过注册器注册。

public class RegistryDynamicTpProcessor implements BeanPostProcessor {
    @Override
    public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
        // 这里的 DynamicTpExecutor 是对动态池执行器的封装
        if (bean instanceof DynamicTpExecutor) {
            DynamicTpExecutor executor = (DynamicTpExecutor) bean;
            // 注册动态池
            registerDtp(executor);
            return executor;
        }
        return bean;
    }
}

这里的注册指的是将动态池实例使用 ConcurrentHashMap 缓存在本地。key为动态池唯一标识名称,value为实例。

业务代码使用时通过注册器提供的静态方法获取对应业务key的实例提交任务即可。

2、 通过配置中心更新动态池配置

实现分布式配置中心提供的属性监听器 PropertyListener。在对应配置更新时,PropertyListener#onUpdate() 方法接收到数据,刷新线程池配置[【这里会实时生效,即使当前某个线程池正在执行任务】。

@Slf4j
@Component
public class DynamicTpPropertyListener implements PropertyListener {
    @Autowired
    private Refresher refresher;

    @Override
    public void onUpdate(Property property) {
        log.info("DynamicTpPropertyListener receive data, property: " + property);
        refresher.refresh(property);
        log.info("DynamicTpPropertyListener update dynamic thread pool success.");
    }

}

3、 刷新机制

上文2中的监听器中使用到了刷新接口。这里的刷新接口 Refresh#refresh 本质上就是对 ThreadPoolExecutor 中一系列 setXXX() 方法的封装。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值