我正在处理的应用程序收到来自外部系统的通知,由于我遇到了一些死锁,因此我要按顺序处理这些通知。
我正在使用Spring的TaskExecutor,它相当于JDK 1.5的Executor。
我已经通过以下方式实现了它:
我有一个包含1方法的java接口:
public interface AsynchronousService {
void executeAsynchronously(Runnable task);
}
以及相应的实现:
public class AsynchronousServiceImpl implements AsynchronousService {
private TaskExecutor taskExecutor;
@Override
public void executeAsynchronously(Runnable task) {
taskExecutor.execute(task);
}
@Required
public void setTaskExecutor(TaskExecutor taskExecutor) {
this.taskExecutor = taskExecutor;
}
}
这是TaskExecutor的配置。 我不确定此配置。 由于我希望通知按顺序执行,因此我为corePoolSize和maxPoolSize都设置了1。 这意味着将仅在线程池中创建一个线程,并从队列中顺序检索通知。 我还为“ WaitForTasksToCompleteOnShutdown”设置了“ false”,以便在执行每个任务后不关闭,而是在破坏spring上下文时关闭。 我的假设通常是否正确?
在这里,我执行代码:
asynchronousService.executeAsynchronously(new Runnable() {
@Override
public void run() {
someMethod.processNotification(notification)
}
});
您如何看待我的实施? 我错过了什么? 我不确定是否/需要在哪里实施错误处理?
编辑:是否有可能在春季调整任务执行器的执行以使用自定义队列? 或确定队列中任务的优先级有多难? 我研究了一些实现,但是大多数实现都使用sratch实现了executor-service而不使用Spring。