인프런 커뮤니티 질문&답변

park님의 프로필 이미지

작성한 질문수

Spring Cloud로 개발하는 마이크로서비스 애플리케이션(MSA)

Users Microservice - JPA ➁

서비스 계층 @Transactional 관련 질문

작성

·

372

0

안녕하세요 선생님,

서비스 계층의 트랜잭션 처리와 관련해 질문이 있습니다.

보통 모놀리식 형태의 웹 어플리케이션의 경우 서비스 계층에 @Transactional을 이용해 트랜잭션 처리를 해주는 것으로 알고 있습니다.

하지만 이번 마이크로서비스 강의에서 나오는 유저 서비스, 오더 서비스, 카탈로그 서비스 모두 @Transactional이 사용되지 않고 있는데 문제가 전혀 없는 것인지 궁금합니다.

답변 2

3

Dowon Lee님의 프로필 이미지
Dowon Lee
지식공유자

안녕하세요, 이도원입니다. 

MSA에서 트랜잭션 간의 데이터 동기화를 위해서 Saga 패턴과 같은 방법으로 처리하실 수 있습니다. 말씀하신 것처럼 여러 서비스 간에 동기화된 데이터를 사용해야 하기 떄문에, 하나의 통합된 데이터베이스(공유 데이터베이스)를 사용하여 데이터를 처리하시거나, 아니면, 데이터베이스를 분리하더라도 롤백 처리가 필요한 부분에서 보상 트랜잭션 또는 모든 데이터들의 롤백 등과 같은 방법으로 이전 데이터를 복원해 주는 방법 등을 사용할 수 있습니다. 본 강의에서는 MSA 패턴 및 데이터에 대한 트랜잭션 처리 방법에 대해서는 다루지 않았었습니다.후속 강의로 준비 중인 내용은 다음과 같습니다. 

- MSA 주요 패턴 (Event Souring, SAGA, CQRS ...)

- Service Mesh 기능의 활용

- CI/CD

감사합니다. 

0

안녕하세요.  거의 1년이 지났지만 다른 분들 도움이 되실거 같아서 제 생각으로 답변드립니다. 강의를 보다가 저도 문득 궁금해서 CrudRepository 가 어떻게 돌아가는지 디버깅해봤습니다.  그러다 보니 CrudRepository의 구현체로 SimpleJpaRepository 의 save를 호출하는 것을 발견했고 해당 메서드에 @Transactional이 붙어있어서 서비스 계층에서 @Transactional이 없어도 동작했던 것입니다. 

 

park님의 프로필 이미지

작성한 질문수

질문하기