[Spring Boot] Scheduler 사용하기 (일정 주기로 실행하는 스프링 스케쥴러)
The Scheduled Annotation in Spring
@Scheduler 를 사용해서 일정한 시간 간격으로, 혹은 특정 일정에 코드가 실행되도록 해보자.
Spring Scheduler
Dependency
spring-boot-starter에 기본적으로 의존 org.springframework.scheduling
Enable Scheduling
- Project Application Class에 @EnableScheduling 추가
@EnableScheduling // 추가
@SpringBootApplication
public class ScheduledrApplication {
public static void main(String[] args) {
SpringApplication.run(ScheduledrApplication.class, args);
}
}
- scheduler를 사용할 클래스에 @Component, 메서드에 @Scheduled 추가
[@Scheduled 규칙]
- 메서드는 void 타입으로
- 메서드는 매개변수 사용 불가
Example
fixedDelay
- 해당 메서드가 끝나는 시간 기준, milliseconds 간격으로 실행
- 하나의 인스턴스만 항상 실행되도록 해야 할 상황에서 유용
@Scheduled(fixedDelay = 1000)
// @Scheduled(fixedDelayString = "${fixedDelay.in.milliseconds}") // 문자열 milliseconds 사용 시
public void scheduledFixedDelayTask() throws InterruptedException {
log.info("Fixed delay task - {}", System.currentTimeMillis() / 1000);
Thread.sleep(5000);
}
fixedRate
- 해당 메서드가 시작하는 시간 기준 milliseconds 간격으로 실행
- 병렬로 Scheduler를 사용할 경우, 클래스에 @EnableAsync, 메서드에 @Async 추가
- 모든 실행이 독립적인 경우에 유용
@Async
@Scheduled(fixedRate = 1000)
// @Scheduled(fixedRateString = "${fixedDelay.in.milliseconds}") // 문자열 milliseconds 사용 시
public void scheduledFixedRateTask() throws InterruptedException {
log.info("Fixed rate task - {}", System.currentTimeMillis() / 1000);
Thread.sleep(5000);
}
fixedDelay + fixedRate
- initialDelay 값 이후 처음 실행되고, fixedDelay 값에 따라 계속 실행
@Scheduled(fixedDelay = 1000, initialDelay = 5000)
public void scheduleFixedRateWithInitialDelayTask() {
long now = System.currentTimeMillis() / 1000;
log.info("Fixed rate task with one second initial delay - {}", now);
}
Cron
- 작업 예약으로 실행
@Scheduled(cron = "0 15 10 15 * ?") // 매월 15일 오전 10시 15분에 실행
// @Scheduled(cron = "0 15 10 15 11 ?") // 11월 15일 오전 10시 15분에 실행
// @Scheduled(cron = "${cron.expression}")
// @Scheduled(cron = "0 15 10 15 * ?", zone = "Europe/Paris") // timezone 설정
public void scheduleTaskUsingCronExpression() {
long now = System.currentTimeMillis() / 1000;
log.info("scheduled tasks using cron jobs - {}", now);
}
Setting Information
fixedDelay
- 이전 작업이 종료된 후 설정 시간(milliseconds) 이후에 다시 시작
- 이전 작업이 완료될 때까지 대기
fixedDelayString
- fixedDelay와 동일, 설정 시간(milliseconds)을 문자로 입력하는 경우에 사용
fixedRate
- 고정 시간 간격으로 시작
- 이전 작업이 완료될 때까지 다음 작업이 진행되지 않음
- 병렬 동작을 사용할 경우 @Async 추가
fixedRateString
- fixedRate와 동일, 설정시간을 문자로 입력하는 경우에 사용
initialDelay
- 설정된 initialDelay 시간 후부터 fixedDelay 시간 간격으로 실행
initialDelayString
- initialDelay와 동일, 설정시간을 문자로 입력하는 경우에 사용
cron
- cron 표현식을 사용한 작업 예약
- 첫번째부터 초(0-59), 분(0-59), 시간(0-23), 일(1-31), 월(1-12), 요일(0-7)
zone
- 미설정시 Local 시간대 사용
참고
https://www.baeldung.com/spring-scheduled-tasks
https://data-make.tistory.com/699
'web > Spring' 카테고리의 다른 글
[Spring MVC] Handler Method 핸들러 메서드 @ModelAttribute (0) | 2022.04.20 |
---|---|
[Spring MVC] Thymeleaf에서 List 보여주기 (How to bind a List object in Thymeleaf) (0) | 2022.04.18 |
[Spring] 빈 생명주기 콜백 - @PostConstruct, @PreDestroy (2) | 2022.04.12 |
[Spring JPA] 일반 Join과 Fetch Join의 차이 (0) | 2022.04.11 |
[Spring] @Autowired 빈 탐색 전략과 @Qualifier, @Primary (0) | 2022.04.08 |
댓글 개