Я пытаюсь преобразовать следующую конфигурацию x7 для 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>
В спецификации Spring, 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) показывает, как я могу подключиться к своему собственному созданному Executor, хотя я не совсем уверен, какой класс это должно быть (я все еще хочу иметь возможность контролировать размер пула, емкость очереди и политику отклонения). Он также показывает, как я могу запланировать мой метод createPartitions с помощью переопределения configureTasks. Тем не менее, я хотел бы иметь возможность назвать мой планировщик (чтобы я мог идентифицировать его потоки) и контролировать его размер пула.
Итак, я хочу знать эти вещи:
1) Какой класс я могу использовать для установки полей исполнителя, которые есть в XML?
2) Есть ли способ создать экземпляр планировщика, чтобы я мог управлять именем и размером пула?