문제의 I. 설명
작업 예약 된 작업의 기본은 단어의 많은 경우 단일 스레드 실행, 예약 된 작업, 그것은 작업의 많은 시간과 예를 들어 정확한 실행에 수 없습니다 발생할 수 있습니다 :
import java.text.SimpleDateFormat;
import java.util.Date;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
@Component
public class TaskTest {
private final Logger log = LoggerFactory.getLogger(TaskTest02.class);
//输出时间格式
private static final SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss:sss");
@Scheduled(cron = "0/15 * * * * ? ")
private void sayHello(){
String dateTime = format.format(new Date());
log.info("{} 向宇宙发出了一声问候: Hello World!", dateTime);
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
@Scheduled(cron = "0/16 * * * * ? ")
private void sayHello2(){
String dateTime = format.format(new Date());
log.info("{} 向宇宙发出了一声问候: 你好,世界", dateTime);
}
}
sayHello가 ()의 실행에있어서, () sayHello2 결과 태스크 실행 스레드의 장기간 직업, 후방의 이행을 지연시키기 때문에 강제 할 때와 같이
II. 솔루션
시나리오 1
클래스의 어떤에 배치 할 수있는 코드의 다음 블록을 추가, 전체 프로젝트는 단순히를 추가 할 수 있습니다
@Bean
public TaskScheduler taskScheduler() {
ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
// 设置scheduler执行线程为3个
scheduler.setPoolSize(3);
return scheduler;
}
시나리오 2 (개인 추천)
당신은 변화없이 구성 클래스, 초과 작업 클래스 나 메소드를 추가 할 수 있습니다
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.TaskScheduler;
import org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler;
/**
* @描述: 多线程执行定时任务
* @日期 2019年5月28日
*/
@Configuration
public class TaskConfig {
/**
* @描述: 所有的定时任务都放在一个线程池中,定时任务启动时使用不同的线程
* @return
* @日期 2019年5月28日
*/
@Bean
public TaskScheduler taskScheduler() {
ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
// 设置scheduler执行线程为3个
scheduler.setPoolSize(3);
return scheduler;
}
}
시나리오 3
클래스는 변화없이, (SchedulingConfigurer이 인터페이스를 구현) 타이밍 작업 클래스 또는 메서드를 구성을 추가 할 수 있습니다
import java.util.concurrent.Executors;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
/**
* @描述: 多线程执行定时任务
* @日期 2019年5月27日
*/
@Configuration
public class SchedulingConfig implements SchedulingConfigurer {
/**
* @描述: 所有的定时任务都放在一个线程池中,定时任务启动时使用不同的线程
* @param taskRegistrar
* @日期 2019年5月27日
*/
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
//设定一个定时任务线程池,数量为3
taskRegistrar.setScheduler(Executors.newScheduledThreadPool(3));
}
}
III. 결과의 구현
우리는이 개별적으로 시간 초과 작업이 다른 스레드에 의해 수행되었습니다 볼 수 있습니다