Как перейти от конфигурации планирования весны XML к конфигурации аннотации / кода?
Я пытаюсь преобразовать следующую конфигурацию XML-задачи Spring в версию, основанную на коде/аннотации:
<task:executor id="xyz.executor"
pool-size="${xyz.job.executor.pool.size:1-40}"
queue-capacity="${xyz.job.executor.queue.capacity:0}"
rejection-policy="CALLER_RUNS"/>
<task:scheduler id="xyz.scheduler" pool size="${xyz.job.scheduler.pool.size:4}" />
<task:annotation-driven executor="xyz.executor" scheduler="xyz.scheduler" />
<bean id='xyzProcessor' class="xyz.queueing.QueueProcessor" />
<task:scheduled-tasks scheduler="xyz.scheduler" >
<task:scheduled ref="partitioner" method="createPartitions" cron="${xyz.job.partitioner.interval:0 0 3 * * *}" />
</task:scheduled-tasks>
в спецификации весны, 28.4.1 (http://docs.spring.io/spring/docs/current/spring-framework-reference/html/scheduling.html), они говорят, что идти от XML так:
<task:annotation-driven executor="myExecutor" scheduler="myScheduler"/>
<task:executor id="myExecutor" pool-size="5"/>
<task:scheduler id="myScheduler" pool-size="10"/>
для конфигурации кода так же просто, как включение @EnableScheduling и / или @EnableAsync.
однако, я не вижу, где я могу фактически создайте экземпляр планировщика. Javadoc для @EnableScheduling (http://docs.spring.io/spring/docs/current/javadoc-api/org/springframework/scheduling/annotation/EnableScheduling.html) показывает, как я могу получить plug In my own created Executor, хотя я не совсем уверен, каким классом он должен быть (я все еще хочу иметь возможность контролировать размер пула, емкость очереди и политику отклонения). Он также показывает, как я могу запланировать метод createPartitions с помощью переопределения configureTasks. Однако я хотел бы иметь возможность назвать мой планировщик (чтобы я мог идентифицировать его потоки) и контролировать его размер пула.
Итак, я хочу знать эти вещи:
1) Какой класс я могу использовать для установки полей исполнителя, которые имеет XML?
2) есть ли способ создать экземпляр планировщика, который я могу контролировать имя и размер пула?
2 ответов
проверить типы AsyncConfigurer
, AsyncConfigurerSupport
и SchedulingConfigurer
. Это вспомогательные типы, которые вы можете использовать для улучшения вашего @Configuration
класс с конфигурациями асинхронного / планирования.
через все из них, и javadoc @EnabledAsync
, вы найдете все методы настройки, необходимые для настройки асинхронного / планирования @Configuration
класса.
пример, приведенный равняет
@Configuration
@EnableAsync
public class AppConfig implements AsyncConfigurer {
@Bean
public MyAsyncBean asyncBean() {
return new MyAsyncBean();
}
@Override
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(7);
executor.setMaxPoolSize(42);
executor.setQueueCapacity(11);
executor.setThreadNamePrefix("MyExecutor-");
executor.initialize();
return executor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return new MyAsyncUncaughtExceptionHandler();
}
}
С
<beans>
<task:annotation-driven executor="myExecutor" exception-handler="exceptionHandler"/>
<task:executor id="myExecutor" pool-size="7-42" queue-capacity="11"/>
<bean id="asyncBean" class="com.foo.MyAsyncBean"/>
<bean id="exceptionHandler" class="com.foo.MyAsyncUncaughtExceptionHandler"/>
</beans>
SchedulingConfigurer
имеет аналогичную настройку для task:scheduler
.
если вы хотите более мелкозернистый контроль, вы можете дополнительно реализовать SchedulingConfigurer
и/или AsyncConfigurer
интерфейсы.
как belows,
Пожалуйста, обратите внимание на бассейны также,
@Configuration
@EnableScheduling
public class CronConfig implements SchedulingConfigurer{
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
taskRegistrar.setScheduler(taskExecutor());
}
@Bean(destroyMethod="shutdown")
public Executor taskExecutor() {
return Executors.newScheduledThreadPool(10);
}
}
и для Asyncs,
@Configuration
@EnableAsync
public class AsyncConfig implements AsyncConfigurer {
@Override
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(5);
executor.setMaxPoolSize(10);
executor.setQueueCapacity(100);
executor.initialize();
return executor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return new SimpleAsyncUncaughtExceptionHandler();
}
}
отметим, что @EnableAsync
и @EnableScheduling
должен быть там, чтобы это работало.