2023/11 7

[Spring Batch] 4장 : 잡 설정 및 실행(Configuring and Running a Job) 3

이번 시간에는 지난에 보던 글에 이어서 JobRegistry부터 다시 읽어볼 것이다. (지난 내용이 궁금하면 여기 클릭!) 1. JobRegistry JobRegistry(그리고 그 부모 인터페이스인 JobLocator) 는 강제적이지는 않지만 context에서 어떤 잡이 사용할 수 있는지 추적하길 원하면 유용할 수 있다. 또한 context가 어디서든지 생성되어왔을 때 application context안에서 job을 중앙에서 모으기에 유용하다. 또 등록된 잡의 다른 속성이나 이름을 수정하기 위해 커스텀 JobRegistry 구현체를 사용할 수 있다. @EnableBatchProcessing을 사용할 때 JobRegistry가 제공된다. 다음 예시는 자신의 JobRegistry를 설정할 수 있는지 보인..

Spring/Spring Batch 2023.11.28

[Spring Batch] 4장 : 잡 설정 및 실행(Configuring and Running a Job) 2

지난 시간에는 잡 설정 및 실행을 읽다가 멈추었다. (지난 내용이 궁금하면 여기 클릭!) 이번에는 지난 내용에 이어서 다시 글을 읽어보려고 한다. 이번 섹션도 아주 길지만 한 번 열심히 읽어보려고 한다. 1. Changing the Table prefix JpaRepository의 또다른 수정 가능한 속성은 메타데이터 테이블의 접두사다. 기본적으로 "BATCH_"로 시작한다. BATCH_JOB_EXECUTION과 BATCH_STEP_EXECUTION은 두개의 예이다. 하지만 이 접두사를 수정할 잠재적인 이유가 있다. 만약 스카미의 이름들이 테이블 이름들에 추가를 하거나 메타데이터 테이블의 하나 이상이 같은 스키마에 있을 필요가 있다면 테이블 접두사는 변경되어야 한다. @Configuration @Enab..

Spring/Spring Batch 2023.11.28

[Spring Batch] 4장 : 잡 설정 및 실행(Configuring and Running a Job) 1

지난 시간에는 Spring Batch의 도메인들에 대해 읽어보았다. (지난 내용이 궁금하면 여기 클릭!) 지난 내용은 spring batch에서 사용되는 domain들에 대해 설명했고 실제로 어떻게 사용하는지에 대한 설명은 없었기에 좀 재미없었을 수 있다. (맞아 쌉노잼이야 에잉 퉤텟!) 이번 시간에는 잡을 설정하고 실행하는 방법에 대해 읽어볼 것이다. domain section에서 전반적인 아키텍처 디자인을 다음 그림을 사용해서 논의했다. Job 객체가 Step을 위한 간단한 컨테이너처럼 보이지만 많은 설정 옵션을 알아야 한다. 더욱이, 어떻게 Job이 작동할 수 있고 어떻게 그 메타데이터가 실행동안 저장될 수 있는지에 대한 많은 옵션을 고려해야한다. 이 챕터는 다양한 설정 옵션과 Job의 런타임 관심..

Spring/Spring Batch 2023.11.23

[Spring Batch] 3장 : 배치의 도메인 언어(The Domain Language of Batch) 2 (Step, StepExecution, ExecutionContext, Job Repository / Launcher, ItemReader / Writer)

지난 시간에 배치의 도메인 언어중 Job, JobInstance, JobParameter, JobExecution에 대해 알아보았다. (지난 내용을 보고 싶다면 여기 클릭!) 저번에 내용이 너무 길었던 관계로 끊은 부분에서 이어서 Step부터 다시 읽을 것이다. 1. Step Step은 한 배치 잡(batch job)의 독립적이고 연속적인 단계를 캡슐화한 하나의 도매인 객체이다. 그러므로 모든 job은 하나 혹은 더 많은 Step들로 구성되있다. Step은 실제 배치 처리를 정의하고 제어하는에 필요한 모든 정보를 포함한다. 이것은 어쩔수없이 모호한 묘사인데(?) 아무 Step의 내용들이 Job을 사용하는 개발자의 재량에 달렸기 때문이다. Step은 개발자의 요구사항에 따라 간단하거나 복잡할 수도 있다. ..

Spring/Spring Batch 2023.11.21

[Spring Batch] 3장 : 배치의 도메인 언어(The Domain Language of Batch) 1 (Job, JobInstance, JobParameter, JobExecution)

지난 시간에 Spring Batch Architecture, Spring Batch Principles and Guidelines 그리고 Spring Processing Strategies 와 약간의 지식들에 대해 보았다. (지난 내용을 보고 싶다면 여기 클릭!) 너무 전략 부분이 쓸데없이 길었던것 같아서 중도에 읽다가 말았다.ㅠㅠ... 지극히 내 개인적인 생각으로는 아 이거 이렇게 해도 되나 싶을 때 다시 보면 될 것 같다.(너무 원론적이야!) 이번에는 배치의 도메인 언어 부분을 읽어볼 것이다. 그리고 읽는 와중에 이런 Job, JobLauncher같은 특별한 것들은 해석이 안된다. 그래서 되도록 본연의 개념을 더 알 수 있도록 영어로 그대로 적고자 한다. (영어 최고야 아잉!) 모든 경험있는 배치 설..

Spring/Spring Batch 2023.11.19

[Spring Batch] 2장 : 스프링 배치 구조(Spring Batch Architecture), 일반적인 배치 원칙(General Batch Principle), 배치 처리 전략(Batch Processing Strategies)

지난번에는 간단하게 스프링 배치가 무엇인지, 무슨 역할을 하는지에 대해 글을 읽어보았다. (지난 내용이 궁금하면 여기 클릭!) 이번에는 스프링 배치의 구조에 대해 공부하려고 한다. 1. 스프링 배치 구조(Spring Batch Architecture) 스프링 배치는 확장 가능성(extensibility)와 다양한 최종 사용자를 염두해 설계했다. 아래 이미지는 최종 사용 개발자(end-user developers)의 편의성과 확장 가능성을 지원하기 위한 계층화 구조이다. 이 계층형 아키텍처(layered architecture)는 세 개의 주요 상위레벨 (high-level) 구성들을 강조한다. (Application, Core, Instrastructure). 어플리케이션(Application)은 모든 ..

Spring/Spring Batch 2023.11.17

[Spring Batch] 1장 : 소개(Introduction)

귀중한 시간을 할애해서(Time is gold~) 스프링 배치에 대해 공부하려고 한다. 그동안 스프링 배치(Spring Batch)에 대해 관심이 많았고 심지어 inflearn에서 15만원에 육박하는 정수원 선생님의 강의도 사서 들었는데 (정확히는 듣다가 좀 남기고 말았다) 아쉬운 점이 좀 있었다. Spring Security 와 마찬가지로 정리를 잘 해주는것은 좋은데 Spring Batch의 경우 양이 너무 방대하고, 이렇게까지 모든 내용을 강의로 만들어서 해야 하는 의문감도 있었다. 꽤 오랜 기간 글을 정리하지 않았는데, 그 이유는 차라리 책을 사서 공부하는것이 도움이 되는 경우에 많이 생겼기 때문이다. 가령, SQL 성능 및 튜닝 관련해서 책을 읽는다던가, 아니면 간단하게 강의를 듣는게 효율이 더 ..

Spring/Spring Batch 2023.11.12