inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

죽음의 Spring Batch: 새벽 3시의 처절한 공포는 이제 끝이다.

0장. 작전1: 시스템 처형 전 무기 점검💀

spring boot 4 + spring batch 6 설정 변경?

96

일공삼

작성한 질문수 1

1

형 스프링부트 4에서는 jdbc starter 추가 안하면 안되던데 뭐지

```build.gradle.kts
description = "batch" dependencies { implementation("org.springframework.boot:spring-boot-starter-jdbc") implementation("org.springframework.boot:spring-boot-starter-batch") implementation("org.springframework.boot:spring-boot-h2console") runtimeOnly("com.h2database:h2") testImplementation("org.springframework.boot:spring-boot-starter-batch-test") }
```

implementation("org.springframework.boot:spring-boot-starter-jdbc")
위 처럼 의존성 명시적으로 처리해주기 전에는

아래 에러떳었어.
Could not autowire. No beans of 'PlatformTransactionManager' type found.

java spring spring-boot spring-batch backend

답변 2

2

KILL-9

오호라... 배치6을 건드리고 있군.

에러를 보니 배치5 기반 코드에서 업데이트한 냄새가 진하게 풍긴다. 아직 배치6 강의의 5장까지 안 왔나보군. 그러니 이 에러 앞에서 멈춘 것이다.

힌트를 주겠다.

spring-boot-starter-batchspring-boot-starter-batch-jdbc

이렇게 교체하면PlatformTransactionManager가 무덤에서 기어나온다. jdbc starter 따로 추가할 필요따위 없다. 💀

5장이 널 기다리고 있다. 순서대로 와라. - KILL-9

LGTM (Looks Gone To Me) - 에러가 사라질 거란 뜻이다.

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

일공삼님, Spring Boot 4와 Spring Batch 6 설정 문제에 대해 질문해 주셨습니다. 주신 내용에서 spring-boot-starter-jdbc 의존성을 추가하니 문제가 해결되었다고 말씀하셨는데요, 이러한 상황이 발생하는 이유를 설명드리겠습니다.

원인

Spring Batch는 내부적으로 트랜잭션 관리를 위해 PlatformTransactionManager 빈을 필요로 합니다. spring-boot-starter-jdbc를 추가하지 않으면, 기본적으로 트랜잭션을 관리할 수 없는 상태가 되어 PlatformTransactionManager를 찾을 수 없다는 오류가 발생할 수 있습니다.

해결 방법

spring-boot-starter-jdbc 의존성을 추가하면, JDBC 관련 기본 설정과 함께 DataSourceTransactionManager를 사용하여 기본적인 트랜잭션 관리 기능을 제공하게 됩니다. 이로써 필요한 빈들이 자동으로 등록되어 문제 없이 Spring Batch를 사용할 수 있게 됩니다.

혹시 유사한 문제가 발생할 경우 다음 게시물도 확인해 보세요:
- Spring Boot 프로젝트에서 트랜잭션 매니저 설정 문제 해결 방법

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Json 요청 처리

1

32

2

[건의][6장][작전1] deprecated 메소드

1

45

2

[예제][3장][작전2] windows 에서 마지막 예제

0

37

1

[오타][3장][작전1] 형 이건 빨리 해줘

2

93

2

[오타] "리스너 활용: 시스템 완전 장악 매뉴얼" 부분

1

59

1

[오타] "JobScope와 StepScope 사용 시 주의사항" 부분

1

65

2

Batch 패키지 설계 — 실무에서 Job 단위 구조

1

94

1

Spring batch를 실행해줄 스케줄러와 batch 실행 환경

1

87

1

메타테이블에 데이터가 생기지 않는 이유

1

105

2

Spring Batch 4.3.10 ExecutionContext 한글 인코딩 이슈 관련 문의

1

105

2

@StepScope 또는 @JobScope와 JobOperator

1

146

5

Remote Partitioning

1

111

2

킬구형 실무에서는 JPA ItemReader / ItemWriter를 더 선호해? 아니면 JDBC itemReader/ItemWriter를 더 선호해?

1

135

2

병렬 중첩

1

101

3

형 코드에 public static class 이게 뭐야 ?

1

134

3

ExitStatus

1

65

2

Batch6: jobOperator.startNextInstance() throws UnexpectedJobExecutionException

1

124

5

jdbc 커서, 페이징에서 일대다 관계 데이터 뻥튀기 조회 처리 방법 질문

1

118

2

SkipPolicy는 여러번 불릴 수 있는가?

1

51

2

형 실무에서 배치 시스템은 어떤 식으로 HA를 구성해??

1

104

1

메타데이터 관리

1

62

2

2장. 작전2: 분산 서버 로그 처형 작전 Resource[]의 대체방안(읽어야할 내용이 매우 커지면?)

1

82

3

2장. 작전2: 분산 서버 로그 처형 작전 (시스템에 의존적인) SystemCommandTasklet 관련 질문

1

95

2

CommandLineJobRunner를 통한 실행

1

85

2