inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

카카오 면접관의 실무 밀착형 Spring Batch: 대용량 데이터 처리의 모든 것

조용히 뒤에서 작업하는 인프라 객체 JobRepository와 JobLanucher 그리고 ExecutionContext

job, step execution 관련 질문 드립니다.

해결된 질문

44

배고프면근손실

작성한 질문수 1

0

안녕하세요.

잡이 어떻게 스텝에서 사용하는 컨텍스트 값까지 가지고 있는지 잘 이해가 되지 않아 질문드립니다.

분명 JobExecutionContext에 넣은 것이 아니라 StepExecutionContext에 값을 저장했는데, 확인해보니 JobExecutionContext에도 동일하게 저장된 것처럼 보여서 헷갈렸습니다.

제가 이해한 바로는 JobExecutionContextStepExecutionContext는 서로 다른 영역이고,
JobExecutionContext는 step 간 공유용, StepExecutionContext는 해당 step 전용으로 알고 있습니다.

그런데 왜 StepExecutionContext에 넣은 값이 JobExecutionContext에도 같은 형태로 보이는지 잘 모르겠습니다.

 

java spring spring-boot spring-batch spring-framework

답변 2

0

Hong

안녕하세요 배고프면근손실님 질문 남겨주셔서 감사합니다.

 

음 아무래도 리스너 설정이 되어있을 확률이 있을꺼 같습니다. ExecutionContextPromotionListener 확인이 필요할꺼같아요. 왜냐하면 해당 리스터는 Step이 완료될 떄 지정한 key를 JobExecutionContext 로 복사하는 역할을 수행하기 떄문에 해당 부분을 확인해보시면 좋을꺼같아요.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 배고프면근손실님,

Spring Batch에서 JobExecutionContextStepExecutionContext 간의 관계와 동작 방식에 대해 궁금해 하신 부분에 대해 설명해 드리겠습니다.

기본적으로 JobExecutionContextStepExecutionContext는 두 개의 별도 영역으로, 각자의 목적을 가지고 있습니다. 전체 플로우에서 각자 상태나 데이터를 관리하기 위한 부분이며, 약간 구체적으로 설명하면 다음과 같습니다:

  1. JobExecutionContext: 이 컨텍스트는 잡 수준에서 데이터를 관리합니다. 여러 스텝에 걸쳐 공통으로 사용될 수 있는 데이터를 저장하는 데 목적이 있으며, 잡의 전체 실행 동안 지속됩니다.

  2. StepExecutionContext: 반면에 이 컨텍스트는 스텝 수준에서 데이터를 관리하며, 각각의 스텝 실행 내에서만 사용됩니다. 스텝이 끝나면 해당 스텝과 관련된 데이터를 순차적으로 처리하는 데 사용되어, 다음 스텝에서는 초기화됩니다.

질문하신 내용 중에서, StepExecutionContext에 특정 값을 넣었을 때, 그것이 JobExecutionContext에도 반영되는 듯이 보이는 현상은 설정이나 코드 내에서 데이터가 명시적으로 두 컨텍스트 사이에 복사되거나, 공유되고 있을 가능성이 있습니다. 보통은 기본적으로 서로 독립적으로 관리되지만, 특정상황에서는 프로그래머가 코드나 설정을 통해 값을 두 컨텍스트 사이에 공유할 수 있습니다.

다음을 점검해보세요:
- 특정 코드에서 StepExecution의 데이터를 JobExecution에 복사하는 부분이 있는지 확인합니다.
- 사용 중인 라이브러리나 프레임워크 설정에서 두 컨텍스트 간 데이터의 전파나 동기화가 자동으로 설정되었는지 살펴봅니다.

관련 내용을 더 자세히 알고 싶으시다면 다음의 유사한 질문과 답변을 참고하실 수 있습니다:
- Spring Batch에서 ExecutionContext 사용 방법
- ExecutionContext와 동일 스코프 내 데이터 공유

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Mark and Sweep

0

8

0

20년 4,5회 13번

0

11

1

GC 알고리즘

0

9

1

용어 질문

0

7

0

호출횟수 질문입니다.

1

20

2

실행과정 질문입니다.

2

23

1

코딩 테스트 All-in-One(Java)' 강의 노션 교재 권한문의

0

16

1

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

15

2

중복내용 제보?!

1

22

2

태어난김에 세계일주 시간 초과

0

16

1

커리큘럼 중 정렬 관련 질문

0

15

1

궁금한점이 여러개 생겼습니다.

1

34

1

혹시 수업자료는 다운받을 수 있는 곳이 없나요?

0

26

2

코테 사이트 로그인 불가

0

22

1

여러 파드 환경에서 단일 실행 보장 방식

0

24

2

XAMPP에서 Apache, DB 재기동 시 접속안되는 문제

0

17

1

실습 권한이 없네요··· 이건 ··· 좀··· 401 에러떠요

0

29

3

훅 내용 안뜸 오류

0

29

2

inheritance startegy 선택시 고려사항

0

21

1

[할인쿠폰] 코테의 바이블[JAVA] 50% 할인 쿠폰 관련

0

23

1

챗봇 기능 구체화 (RAG)

0

27

2

Entity 동등성 비교

0

18

1

패키지 구분에 대해 궁금한게 있습니다

0

25

2

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

0

29

1