SpringBoot에서 예약된 작업을 사용할 때 특정 작업 실행 시 많은 리소스를 차지하여 다른 작업 실행에 실패하는 현상이 발견되었습니다.
다음 시뮬레이션 시나리오와 유사하게 test1 예약 작업 시뮬레이션의 실행 시간은 5초이며 동시에 test2 작업 실행에도 영향을 미치므로 test2 작업도 5초마다 실행됩니다.
@Scheduled(fixedRate = 1000) public void test1() throws InterruptedException { log.info(Thread.currentThread().getName() + " | task01 "); Thread.sleep(5000); } @Scheduled(fixedRate = 2000) public void test2() { log.info(Thread.currentThread().getName() + " | task02 "); }
관련 정보를 검토한 결과 예약된 작업의 기본 스레드 수는 단 하나인 것으로 확인되었습니다. 예약된 작업은 한 번의 실행이 완료된 후 동기적으로 예약됩니다. 이는 문제의 직접적인 원인이 됩니다.
@Bean public TaskScheduler taskScheduler() { ThreadPoolTaskScheduler taskScheduler = new ThreadPoolTaskScheduler(); // 设置线程数量 taskScheduler.setPoolSize(50); return taskScheduler; }
구성을 추가하고 TaskScheduler 스레드 수를 여러 개로 설정하여 실행 시 비동기식으로 실행되고 예약된 각 작업이 서로 영향을 미치지 않도록 합니다.
다음 Java 유틸리티 패키지에 포함된 TimerTask를 사용하면 예약된 작업도 실행할 수 있습니다.
다음 매개변수에서 TimerTask는 실행될 작업입니다. 0은 첫 번째 실행이 0초 지연된다는 의미이고, 3000은 3000밀리초마다 실행된다는 의미입니다.
위 내용은 SpringBoot에서 예약된 단일 스레드 실행 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!