inflearn logo
강의

Course

Instructor

Kakao Interviewer's Hands-on Spring Batch: Everything About Large-Scale Data Processing

The infrastructure objects working quietly in the background: JobRepository, JobLauncher, and ExecutionContext

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

Resolved

45

hungrylosemuscle

1 asked

0

안녕하세요.

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

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

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

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

 

java spring spring-boot spring-batch spring-framework

Answer 2

0

Hong

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

 

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

0

communityai8509

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

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

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

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

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

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

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

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

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

멀티스레드

0

2

1

N+1 관련해서 질문있습니다.

0

8

1

성능 오버헤드

0

11

1

다음 강의는 언제 올려주시는지요?

0

11

0

하단 파일이 열리지 않습니다

0

10

0

ssh-keygen -t rsa -P "" 등 ssh 암호화? 는 하둡에서 필수인가요?

0

12

1

강의 중복 확인 요청

0

15

1

volatile에 대해 질문 있습니다.

1

25

2

Mark and Sweep

1

23

1

20년 4,5회 13번

0

18

1

GC 알고리즘

1

24

2

용어 질문

1

19

1

호출횟수 질문입니다.

1

28

2

실행과정 질문입니다.

2

30

1

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

0

20

1

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

0

24

2

중복내용 제보?!

1

28

2

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

0

22

1

커리큘럼 중 정렬 관련 질문

0

20

1

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

1

42

1

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

0

29

2

코테 사이트 로그인 불가

0

27

1

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

0

26

2

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

0

19

1