스프링배치 기본 구성
Job
하나의 배치 작업을 정의, 예를 들어 "API 서버의 사용로그 테이블의 데이터를 로그 분석 시스템으로 옮기는 배치"
Job Instance
배치가 실제 실행되면, 각각의 실행을 Instance라고 한다. 예를 들어 Batch Job이 매주 한번씩 수행된다고 할때, 각각의 수행되는 Batch Job을 Batch Instance라고 한다.
Job Execution
배치가 실행될때, 각 배치의 실행시, 실제 수행된 Execution을 정의한다. 예를들어 BatchJob이 월요일 오전에 수행되었을때, 첫번째 실패하고, 두번째 Retry에 의해 성공되었다면, 이 각각은 다른 Job Execution이 되고, 같은 작업을 시도하였기 때문에, 같은 Job Instance가 된다.
Job Parameter
매번 배치 작업이 수행될때마다 전달되는 Parameter이다. 예를 들어 매주 수행되는 배치가 있을때, 시작 시간, 데이터를 읽을 범위 등을 지정하여, Batch Job Instance를 생성한다면, 이렇게 넘어가는 인자가 JobParameter이다.
Spring에서 Batch Job 구성
Step
Spring에서 BatchJob은 Step의 모음으로 구성된다. Job은 Step이 순차적으로 수행되게 한다.
Tasklet
Tasklet은 각 Step에서 수행되는 로직이다. 개발자가 Custom Logic을 만들수도 있고, 또는 보통 Batch의 경우 데이터 ETL(Extract, Transform, Loading)하는 형태이기 때문에, Spring Batch에서 미리 정의해놓은 Reader, Processor, Writer Interface를 사용할 수 있다.
1) ItemReader - 데이터를 읽는 컴포넌트
2) ItemProcessor - 읽은 데이터를 처리
3) ItemWriter - 처리한 데이터를 저장
<job id="ioSampleJob">
<step id="step1" next="step2">
<tasklet>
<chunk reader="itemReader" writer="itemWriter" commit-interval="2"/>
</tasklet>
</step>
<step id="step2">
<tasklet ref="CustomTaskletClass" />
</step>
</job>
스프링배치 실행 프로세스
출처: https://terasoluna-batch.github.io/guideline/5.0.0.RELEASE/en/Ch02_SpringBatchArchitecture.html
'프로그래밍(TA, AA) > JVM 언어' 카테고리의 다른 글
[자바] 단일 연산 변수와 넌블로킹 동기화 (0) | 2018.04.16 |
---|---|
[자바] 스레드풀 튜닝 및 Executor 고급 활용 (0) | 2018.04.12 |
[자바] 람다(lambda)가 이끌어 갈 모던 JAVA(2) (0) | 2018.03.30 |
[자바] Executor 프레임워크 (0) | 2018.03.26 |
[자바] 람다(lambda)가 이끌어 갈 모던 JAVA(1) (0) | 2018.03.26 |