inflearn logo
강의

講義

知識共有

死のSpring Batch:午前3時の凄まじい恐怖は、もう終わりだ。

0章。作戦1:システム処刑前の武器点検💀

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

100

dlehdgks1034117

投稿した質問数 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

communityai8509

안녕하세요, 인프런 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

33

2

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

1

48

2

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

0

39

1

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

2

95

2

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

1

61

1

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

1

68

2

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

1

97

1

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

1

89

1

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

1

108

2

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

1

106

2

@StepScope 또는 @JobScope와 JobOperator

1

148

5

Remote Partitioning

1

112

2

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

1

137

2

병렬 중첩

1

103

3

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

1

136

3

ExitStatus

1

67

2

Batch6: jobOperator.startNextInstance() throws UnexpectedJobExecutionException

1

126

5

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

1

120

2

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

1

52

2

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

1

107

1

메타데이터 관리

1

64

2

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

1

84

3

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

1

97

2

CommandLineJobRunner를 통한 실행

1

86

2