인프런 커뮤니티 질문&답변

개감님의 프로필 이미지
개감

작성한 질문수

스프링 배치

@JobScope / @StepScope - 기본개념 및 설정

@StepScope를 사용한 것과 안한 것의 차이점 문의

작성

·

670

0

안녕하세요 

챕터 : 스프링 배치 실행 - flow

강의 : @JobScope / @StepScope - 기본개념 및 설정

실습 및 테스트 부분에 문의 있습니다.

 

런터임시 tasklet2()를 통해서 Tasklet빈 생성 할

@StepScope와 @Value를 사용하여 

StepExecutionContext에 접근하여 원하는 값을

얻어오는 것을 실습해봤는데요

 

이렇게 @StepScope와 @Value를 통해서 하는 것과

바로 Tasklet에서 매개변수로 넘어오는

stepContribution을 통해서 접근하여 값을 얻어오는 것의

차이점은 어떤 걸까요?

 

해당 실습에서는 둘다 결과가 같아서 차이점이 헷갈립니다.

답변 1

6

정수원님의 프로필 이미지
정수원
지식공유자

결과가 동일한 것은 맞지만 처리하는 방식이 다르다고 할 수 있습니다.

@StepScope를 사용하면 스프링의 표현식 언어를 사용해서 런타임 시점에 @StepScope를 선언한 빈이 생성되는 동시에 파라미터 바인딩이 적용되어 좀 더 유연한 설계가 가능해 집니다.

stepContribution 와 같은 객체를 참조해서 사용하지 않아도 표현식 언어로 접근이 가능해 지는거죠

구동시점이 아닌 실행 시점에 JobParameter 의 파라미터 값을 설정하고 실제 빈을 호출하면 해당 파라미터를 표현식 언어로 주입받을 수 있게 됩니다.

이것이 가능하게 하는 것이 @StepScope 를 선언해 주었기 때문입니다.

또한 런타임 시점에 빈이 생성된다는 것은 지연 생성이 가능하다는 것이고 특히 병렬처리 환경에서는 여러 스레드가 실제 빈을 호출하는 시점에 @StepScope 이 선언된 빈의 객체가 스레드마다 생성되어 할당되기 때문에 스레드에 안전한 실행이 가능해 집니다

가령 예를 들어 여러 스레드가 하나의 Step 객체빈을 공유해서 사용할 경우 Tasklet 내 멤버 변수가 존재한다면   그 멤버 변수의 동시적 접근에 따른 동시성 문제 등 스레드 안전성을 해칠 수 있으나 @StepScope 가 선언되면 Step 객체를 여러 스레드가 공유하지 않고 스레드마다 생성되어 할당되기 때문에 멤버 변수를 공유할 수 없어 스레드에 안전하게 됩니다. 

요약하자면

1. Step 빈의 생성이 구동시점이 아닌 런타임 시점에 생성되어 객체의 지연로딩이 가능해진다

2. 파라미터의 주입을 구동시점이 아닌 런타임 시점에 표현식 언어로 유연하게 주입받을 수 있다

3. 병렬 처리시에 스레드마다 Step 객체가 생성되어 할당되기 때문에 멤버 변수등의 동시적 접근과 같은 동시성 문제를 차단할 수 있다

자세한 내용은 강의에서 설명하고 있으니 참고해 주시기 바랍니다.

개감님의 프로필 이미지
개감

작성한 질문수

질문하기