일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 명령어
- 추상클래스
- PostgreSQL
- 리눅스
- 티스토리챌린지
- Linux
- analytics4
- 트랜잭션
- MariaDB
- git
- oracle
- JPA
- SQL
- MongoDB
- 오블완
- 인터페이스
- mssql
- mysql
- 호이스팅
- rsync
- 차이점
- DBMS
- group by
- Javascript
- Exception
- spring
- IntelliJ
- docker
- java
- 자바
- Today
- Total
hanker
spring boot(java) - 스케쥴러(Scheduler) 만들기 (1) - quartz 본문
스케쥴러 만들기 (quartz)
우선 Spring boot 프로젝트를 만들고 pom.xml에 quartz dependency를 추가한다.
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-quartz</artifactId>
</dependency>
추가 후 프로젝트를 실행하면
Scheduler class: 'org.quartz.core.QuartzScheduler' - running locally.
NOT STARTED.
Currently in standby mode.
Number of jobs executed: 0
Using thread pool 'org.quartz.simpl.SimpleThreadPool' - with 10 threads.
Using job-store 'org.quartz.simpl.RAMJobStore' - which does not support persistence. and is not clustered.
이런 메시지가 뜨면 정상적으로 적용이 된것이다.
그 다음 Job 클래스 파일을 만든다. (com.hanker.hankerbatch.run.HankerJobA.java)
<code>
@Component
public class HankerJobA extends QuartzJobBean {
private static final Logger log = LoggerFactory.getLogger(HankerJobA.class);
@Override
protected void executeInternal(JobExecutionContext jobExecutionContext) throws JobExecutionException {
log.info("매 시간 실행 될 작업 작성 공간");
}
}
Job 클래스를 만들었고, 이제 Job 클래스를 실행시키기 위해 JobSetting파일을 만들고 설정해준다.
(com.hanker.hankerbatch.conf.JobSetting)
<code>
@Configuration
public class JobSetting {
@Autowired
private Scheduler scheduler;
@PostConstruct
public void start(){
JobDetail jobDetail = buildJobDetail(HankerJobA.class, new HashMap());
try{
scheduler.scheduleJob(jobDetail, buildJobTrigger("0/20 * * * * ?"));
} 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();
}
}
20초간격으로 실행시키는 Job 스케쥴러를 만들었다.
실행시켜보면
20초 간격으로 실행되는것이 확인된다.
다음 글은 Job 스케쥴 2개 (JobA, JobB)를 만들어서 특정 조건에 Job 스케쥴(JobA)을 종료시키는 방법에 대해 작성하겠다.
spring boot - 스케쥴러(scheduler) 작업 중지시키기 (2)
기존에 작업했던 스케쥴러 만들기 (1)를 이어서 시작한다. hanke-r.tistory.com/101 SpringBoot - 스케쥴러(Scheduler) 만들기 스케쥴러 만들기 (quartz) 우선 Spring boot 프로젝트를 만들고 pom.xml에 quartz de..
hanke-r.tistory.com
'SPRING' 카테고리의 다른 글
Spring - local image 가져오기 (0) | 2021.04.20 |
---|---|
spring boot(java) - 스케쥴러(scheduler) 작업 중지시키기 (2) - quartz (1) | 2021.04.12 |
ApexCharts stepline(계단식 차트) 그리기 (0) | 2021.04.02 |
Spring - 코드 수정시 자동 재실행 (0) | 2021.02.06 |
Spring - Runnable JAR File Export ( Launch configuration 목록이 없을때) (0) | 2021.02.06 |