Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- macvlan
- 오블완
- 애널리틱스4
- 자바
- ANTIFRAGILE
- 르세라핌
- gtihub
- git pat
- 데이터내보내기
- 명령어
- Python
- JPQL
- java
- db종류
- 컬렉션프레임워크
- DBMS
- JPA
- spring
- 11월순위
- git branch 삭제
- codeium
- docker
- IntelliJ
- 티스토리챌린지
- pat발급
- 도커이미지
- analytics4
- docker build
- docker push
Archives
- Today
- Total
hanker
spring boot(java) - 스케쥴러(scheduler) 작업 중지시키기 (2) - quartz 본문
반응형
기존에 작업했던 스케쥴러 만들기 (1)를 이어서 시작한다.
두개의 작업을 실행시키기 위해 기존에 run패키지에서 Job클래스를 하나 더 추가해준다
JobA와 JobB의 실행을 위해 JobSetting.java 코드를 수정한다.
반응형
@Configuration
public class JobSetting {
@Autowired
private Scheduler scheduler;
@PostConstruct
public void start(){
JobDetail jobDetailA = buildJobDetail(HankerJobA.class, new HashMap());
JobDetail jobDetailB = buildJobDetail(HankerJobB.class, new HashMap());
try{
scheduler.scheduleJob(jobDetailA, buildJobTrigger("0/20 * * * * ?"));
scheduler.scheduleJob(jobDetailB, buildJobTrigger("0/30 * * * * ?"));
} catch(SchedulerException e){
e.printStackTrace();
}
}
public Trigger buildJobTrigger(String scheduleExp){
return TriggerBuilder.newTrigger()
.withSchedule(CronScheduleBuilder.cronSchedule(scheduleExp)).build();
}
public JobDetail buildJobDetail(Class job, Map params){
JobDataMap jobDataMap = new JobDataMap();
jobDataMap.putAll(params);
return newJob(job).usingJobData(jobDataMap).build();
}
}
- jobDetailA = 20초마다 실행
- jobDetailB = 30초마다 실행
( 리스트로 담아서 실행시키고 싶은데 방법을 찾으면 수정할 예정이다. )
프로젝트를 실행시켜보자
잘 실행된다.
이제 JobA의 작업을 중지시켜보자.
JobA의 jobKey를 생성한 후 특정시간에 도달하면 중지하는 소스이다.
임시로 시간으로 지정했지만, DB를 연결해서 값을 불러와 중지할 수도 있다.
@Component
public class HankerJobA extends QuartzJobBean {
private static final Logger log = LoggerFactory.getLogger(HankerJobA.class);
private JobKey jobKey = null;
@Autowired
private SchedulerFactoryBean schedulerFactoryBean;
@Override
protected void executeInternal(JobExecutionContext jobExecutionContext) throws JobExecutionException {
log.info("작업 스케쥴러 A");
jobKey = jobExecutionContext.getJobDetail().getKey();
Scheduler scheduler = schedulerFactoryBean.getScheduler();
// 조건을 걸기위해 DateTime 설정
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm");
Date nowDate = new Date();
try{
Date date = sdf.parse("2021-04-12 12:12");
String newDate = sdf.format(nowDate);
nowDate = sdf.parse(newDate);
if(nowDate.compareTo(date) == 0){
scheduler.pauseJob(jobKey);
log.info("작업이 종료되었습니다.");
}
} catch(Exception e){
e.printStackTrace();
}
}
}
Date, String 변환 설정
hanke-r.tistory.com/92?category=751708
이제 프로젝트를 실행해보자.
로그를 보면 설정한 시간에 JobA의 스케쥴이 중지된 걸 확인할 수 있다.
반응형
'SPRING' 카테고리의 다른 글
Spring boot - Log 사용 (0) | 2021.04.26 |
---|---|
Spring - local image 가져오기 (0) | 2021.04.20 |
spring boot(java) - 스케쥴러(Scheduler) 만들기 (1) - quartz (0) | 2021.04.11 |
ApexCharts stepline(계단식 차트) 그리기 (0) | 2021.04.02 |
Spring - 코드 수정시 자동 재실행 (0) | 2021.02.06 |