Hello World

Spring Batch 개념 정리 본문

Spring/3.x

Spring Batch 개념 정리

EnterKey 2016. 2. 22. 14:10
반응형

Spring Batch의 주요 개념

 




Job

하나의 배치 작업을 정의. 예를 들어 "API 서버의 사용로그 테이블의 데이타를 로그 분석 시스템으로 옮기는 배치"

Job Instance

배치가 실제 실행되면, 각각의 실행을 Instance라고 한다. 예를 들어 Batch Job이 매주 한번씩 수행된다고 할때, 각각의 수행되는 Batch Job을Batch Instance라고 한다.

Job Execution

배치가 실행될때, 각 배치의 실행시, 실제 수행된 Execution을 정의한다. 예를 들어 Batch Job이 월요일 오전에 수행되었을때, 첫번째 실패하고,두번째에 Retry에 의해 성공되었다면, 이 각각은 다른 Job Execution이 되고, 같은 작업을 시도하였기 때문에, 같은 Job Instance가 된다.

Job Parameter

매번 배치 작업이 수행될때 마다 전달되는 Parameter이다. 예를 들어 매주 수행되는 배치가 있을때, 시작 시간, 데이타를 읽을 범위 등을 지정하여, Batch Job Instance를 생성한다면, 이렇게 넘어가는 인자가 JobParameter이다.

 

Spring에서 Batch Job의 구성

Step

Spring에서 Batch Job은 Step의 모음으로 구성된다. Job은 Step이 순차적으로 수행되게 된다.

Tasklet

Tasklet은 각 Step에서 수행되는 로직이다. 개발자가 Custom Logic을 만들 수 도 있고, 또는 보통 Batch의 경우 데이타를 ETL (Extract, Transform, Loading) 하는 형태이기 때문에, Spring Batch에서 미리 정의해놓은 Reader, Processor,Writer Interface를 사용할 수 있다.

     ItermReader - 데이타를 읽는 컴포넌트

     ItemProcessor - 읽은 이타를 처리

     ItemWriter - 처리한 데이타를 저장

 

이해를 돕기 위한 Sample Configuraion

<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>

 

※ Custom Tasklet을 이용한 간단한 예제 http://bcho.tistory.com/762


출처: http://bcho.tistory.com/763

반응형

'Spring > 3.x' 카테고리의 다른 글

Spring – JMS 적용하기  (0) 2016.02.22
JMS 개념 및 Spring에서 지원하는 JMS, MDP  (0) 2016.02.22
Spring XD  (0) 2016.02.19
Eclipse Console Log 파일로 보기  (0) 2016.02.16
[펌]서비스에 인터페이스를 사용해야 하나?  (0) 2016.02.11
Comments