gpt4 book ai didi

java - 如何在 Spring boot AsyncConfigurer 中使用优先级队列

转载 作者:行者123 更新时间:2023-11-30 05:59:22 25 4
gpt4 key购买 nike

我有一个应用程序,其中有多个线程从 jms 目标读取消息。监听器线程读取消息,对其进行一些更改并调用不同类的其他几个方法。这些方法使用 @Async 注释进行注释,所有方法都使用自定义 ThreadPoolTask​​Executor 并行执行。

@Override
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(corePoolSize);
executor.setMaxPoolSize(maxPoolSize);
executor.setQueueCapacity(queueCapacity);
executor.setKeepAliveSeconds(keepAliveSeconds);
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
executor.setTaskDecorator(new LoggingTaskDecorator());
executor.initialize();
return executor;
}

到目前为止,所有消息都被认为具有同等优先级,一切都很好,因为如果没有任何 Executor 线程可用,所有消息都会进入 LinkedBlockingQueue

现在,存在这样的要求:从队列中读取的特定类型的消息预计比从队列中读取的任何其他消息具有更高的优先级。

目前,我正在使用“org.springframework.scheduling.concurrent.ThreadPoolTask​​Executor”,它没有提供任何可以将优先级队列设置为阻塞队列实现的方法。

您能帮我解决这个问题吗?或者说现有的系统设计无法适应这种变化?或者处理这种情况的最佳解决方案是什么?

谢谢!

最佳答案

只需重写 createQueue 方法即可。另外,您应该使用 @Bean 方法来创建 bean 的实例,这样 Spring 可以正确管理生命周期,这是一件小而重要的事情(否则关闭将无法正常工作)..

@Override
public Executor getAsyncExecutor() {
return taskExecutor();
}

@Bean
public ThreadPoolTaskExecutor taskExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor() {
protected BlockingQueue<Runnable> createQueue(int queueCapacity) {
return new PriorityBlockingQueue<>(queueCapacity);
}
};
executor.setCorePoolSize(corePoolSize);
executor.setMaxPoolSize(maxPoolSize);
executor.setQueueCapacity(queueCapacity);
executor.setKeepAliveSeconds(keepAliveSeconds);
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
executor.setTaskDecorator(new LoggingTaskDecorator());
return executor;
}

像这样的东西应该可以工作。 createQueue 方法现在创建一个 PriorityBlockingQueue,而不是默认的 LinkedBlockingQueue

关于java - 如何在 Spring boot AsyncConfigurer 中使用优先级队列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52537041/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com