1. Обзор
Когда однопоточного выполнения недостаточно, мы можем использовать аннотации из пакета org.springframework.scheduling.annotation
.
В этом кратком руководстве мы собираемся изучить аннотации Spring Scheduling.
2. @EnableAsync
С помощью этой аннотации мы можем включить асинхронную функциональность в Spring.
Мы должны использовать его с @Configuration
:
@Configuration
@EnableAsync
class VehicleFactoryConfig {}
Теперь, когда мы включили асинхронные вызовы, мы можем использовать @Async
для определения поддерживающих его методов.
3. @EnableScheduling
С помощью этой аннотации мы можем включить планирование в приложении.
Мы также должны использовать его вместе с @Configuration
:
@Configuration
@EnableScheduling
class VehicleFactoryConfig {}
В результате теперь мы можем периодически запускать методы с помощью @Scheduled
.
4. @Асинхронный
Мы можем определить методы, которые хотим выполнять в другом потоке , поэтому запускать их асинхронно.
Для этого мы можем аннотировать метод с помощью @Async
:
@Async
void repairCar() {
// ...
}
Если мы применим эту аннотацию к классу, то все методы будут вызываться асинхронно.
Обратите внимание, что для работы этой аннотации нам необходимо включить асинхронные вызовы с конфигурацией @EnableAsync
или XML.
Подробнее о @Async
можно узнать в этой статье .
5. @Запланировано
Если нам нужен метод для периодического выполнения , мы можем использовать эту аннотацию:
@Scheduled(fixedRate = 10000)
void checkVehicle() {
// ...
}
Мы можем использовать его для выполнения метода с фиксированными интервалами или можем настроить его с помощью cron-подобных выражений .
@Scheduled
использует функцию повторяющихся аннотаций Java 8, что означает, что мы можем отметить метод несколько раз:
@Scheduled(fixedRate = 10000)
@Scheduled(cron = "0 * * * * MON-FRI")
void checkVehicle() {
// ...
}
Обратите внимание, что метод, аннотированный @Scheduled
, должен иметь возвращаемый тип void .
Более того, мы должны включить планирование, чтобы эта аннотация работала, например, с @EnableScheduling
или конфигурацией XML.
Подробнее о планировании читайте в этой статье .
6. @Расписания
Мы можем использовать эту аннотацию для указания нескольких правил @Scheduled
:
@Schedules({
@Scheduled(fixedRate = 10000),
@Scheduled(cron = "0 * * * * MON-FRI")
})
void checkVehicle() {
// ...
}
Обратите внимание, что начиная с Java 8 мы можем добиться того же с помощью функции повторяющихся аннотаций, как описано выше.
7. Заключение
В этой статье мы увидели обзор наиболее распространенных аннотаций планирования Spring.
Как обычно, примеры доступны на GitHub .