Spring 부팅 시작 코드, 타이머 기능을 활성화하기 위해 @EnableScheduling 주석이 추가되었습니다
@SpringBootApplication @EnableScheduling // 开启定时功能 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class,args); } }
스케줄링 작업 코드, 작업 클래스는 @Component 주석을 통해 IoC 컨테이너에 주입되어야 합니다
@Component public class TestSchedulingTask { // 这个cron表达式代表从0秒开始,每过3秒执行一次。 @Scheduled(cron = "0/3 * * * * ?") public void test(){ // 大家可以根据公司的业务来实现,更希望是@Autowrite注入service层的接口,业务逻辑写在service层中。 // 这里测试我就输出当前系统时间了... Date date = new Date(System.currentTimeMillis()); String rule = "yyyy-MM-dd HH:mm:ss"; SimpleDateFormat simpleDateFormat = new SimpleDateFormat(rule); String format = simpleDateFormat.format(date); System.out.println(format); } }
여기에 참고하세요 각 모든 작업 메서드에는 @Scheduled로 주석을 달고 cron 표현식을 지정해야 합니다.
안심하셔도 됩니다. 온라인에서 cron 표현식을 생성하는 웹사이트도 있습니다. 콘솔 출력 결과를 살펴보겠습니다.
cron 표현식
field | range | 허용 문자 |
초(초) | 0-59 | ,/ -* |
분 (분) | 0-59 | ,/-* |
시(시) | 0-23 | ,/-* |
날짜(일) | 1-31 (당신 월이 일치하지 않는다는 점을 고려해야 함) | ,/-*?LW |
월(월) | 1-12 (해당 영어 약어도 가능) | ,/-* |
day of week ) | 1-7 | ,/-*?L |
년(년) | 기본적으로 사용되지 않는 항목입니다 | 기본적으로 사용되지 않는 항목입니다 |
허용 문자 설명:
,: 여러 값이 포함된 열거형입니다. 예를 들어 초의 5와 20은 5초와 20초의 트리거를 나타냅니다.
/: 값 1/값 2, 값 1은 시작 시간을 나타내고, 값 2는 빈도를 나타냅니다. 예를 들어 제 경우에는 0초부터 시작하여 3초마다 트리거됩니다.
-: 기간 값부터 기간까지의 범위 값입니다.
*: 모든 범위에 공통됩니다.
?: 날짜와 주에만 존재합니다. 매월 2일에 실행하고 싶지만 주에 *를 사용하면 매일 실행되므로 버그가 발생합니까? 교체 *.
L: 마지막을 의미하며 날짜와 주에 나타납니다. 예를 들어 날짜에 L을 사용하면 해당 월의 마지막 날을 나타내고, 주에 3L을 사용하면 마지막 수요일에 대한 트리거를 나타냅니다.
W: 근무일을 나타냅니다. 9W를 사용하는 경우 9일이 월요일인 경우 8일에 직접 실행됩니다. 9일은 일요일이므로 월요일에 실행됩니다.
위 내용은 SpringBoot로 타이머를 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!