inflearn logo
강의

Course

Instructor

Introduction and Practice of MSA for Non-Majors (feat. Spring Boot)

MSA Project Requirements and Design

Microservice 에 DB 띄우기

75

SJ

155 asked

0

Microservice 에 DB 를 띄우게 될때 DB 를 여러대 띄우는것 같은데

저렇게 하지않고

하나의 DB 를 띄우고 스키마로 분리하는 경우도 있나요 ??

너무 낭비가 되지 않나 ?? 생각도 들어서요

아키텍처 spring-cloud kafka msa devops

Answer 2

0

jscode

안녕하세요 ! 질문 잘 해주셨어요 ~

질문해주신 내용에 답변 드려볼게요 !

"하나의 DB 를 띄우고 스키마로 분리하는 경우도 있나요 ??"

-> 네 ! 특히 초기 단계의 서비스나 리소스가 제한적인 환경에서는 DB를 하나만 띄우고 스키마만 분리해서 운영하기도 해요 ~

비용과 관리 복잡도를 줄일 수 있어서 현실적인 타협안이 되기도 해요 !

다만 강의에서 DB를 서비스별로 완전히 분리하는 방식으로 구성한 이유는, MSA의 핵심 개념인 "독립성"을 제대로 이해하고 경험해보는 것이 목적이기 때문이에요!

실무에서도 DB를 물리적으로 완전히 분리하는 게 MSA의 이상적인 형태인 건 맞아요 !

DB를 하나로 공유하게 되면 한쪽 서비스의 DB 장애나 성능 저하가 다른 서비스에도 영향을 미치게 되고, 서비스 간 독립 배포도 어려워질 수 있거든요 ~

결국 "DB를 몇 대 띄우느냐"보다는 서비스끼리 서로의 DB에 직접 접근하지 않고 API로만 통신하는 독립성을 지키는 것이 MSA의 핵심이라고 보시면 돼요 !

실제 운영 환경에서는 비용, 팀 규모, 서비스 성격에 따라 유연하게 결정하게 돼요 :)

추가로 궁금하신 점 있으시면 언제든 추가 질문 남겨주세요~~

0

communityai8509

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

Microservices Architecture(MSA)에서는 각 마이크로서비스가 자신만의 데이터베이스를 갖는 것이 원칙입니다. 각 서비스가 독립적으로 책임을 지고, 다른 서비스와의 결합도가 낮아야 하기 때문에, 데이터베이스도 독립적으로 운영하는 것이 이상적입니다.

각 서비스별 독립적인 데이터베이스 운영의 이유

  1. 독립적인 확장: 서비스별로 독립적으로 확장할 수 있습니다. 특정 서비스의 트래픽이 급증해도 다른 서비스에 영향을 미치지 않습니다.

  2. 장애 격리: 한 서비스의 데이터베이스에 장애가 발생하더라도 다른 서비스에는 영향을 미치지 않게 됩니다.

  3. 보안 및 데이터 보호: 서비스마다 다른 보안 정책을 적용할 수 있어, 민감한 데이터는 별도로 보호할 수 있습니다.

그러나, 상황에 따라서는 하나의 데이터베이스 인스턴스를 여러 스키마로 분리하여 사용하는 경우도 있습니다. 주로 데이터베이스 라이선스 비용 문제나, 인프라 비용을 절감해야 하는 상황에서 고려됩니다.

스키마 분리 사용의 단점

  1. 결합도 증가: 스키마를 분리해서 사용하면, 여러 서비스가 동일한 데이터베이스 인스턴스를 공유하기 때문에 결합도가 생길 수 있습니다.

  2. 성능 문제: 한 계약을 사용하는 여러 서비스가 동시에 데이터베이스에 접속하게 되면, 성능 병목 현상이 발생할 수 있습니다.

  3. 운영 복잡성: 여러 스키마의 변경이 필요한 경우, 관리 및 운영이 복잡해질 수 있습니다.

이와 관련한 더 구체적이고 실질적인 사례나 질문들은 다음의 유사한 게시물을 참고하시면 도움이 될 것입니다:

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

19강 15_2) 템블릿에 List가 없는경우는 어떻게 해야되나요?

0

8

1

15강 12-3) 값 제출후 mysql 저장이 안됩니다.

0

11

2

Pull 방식 아키텍처3 문의

1

17

2

4. Container 빌드 & 저장하기 - 자료 관련

1

23

2

Nat Gateway

0

26

2

실무 내용 문의드려요

0

24

2

쿠버네티스 어나더 클래스-Sprint 1, 2 강의 관련 질문이있습니다.

1

27

1

혹시 강의에서 사용하시는 손글씨 도구? 프로그램이 뭔가요??

0

27

1

보안그룹 아웃바운드 규칙

0

13

1

pg사가 있다고 가정하면

0

25

1

Kafka Cluster 구성도 질문

0

23

1

데이터베이스 13번 문제

0

43

2

jar 파일 빌드

-1

23

1

배포 파이프라인 구축 후 마주하게 되는 고민들 (💻 실습)

1

30

2

user-service jwt

0

58

2

MSA에서 서비스별 DB 작성에 관해

0

93

2

MSA 프로젝트 요구사항 및 설계 에서의 FK

0

77

2

보상 트랜잭션을 위한 catch 문 안에서 에러가 발생한다면 어떻게 되는 건가요?

0

79

2

하나의 consumer에서 두가지 이상의 topic의 메세지를 받고자 할때 받는 메세지에 시간차와 상관없이 하나의 consumer에서 받을수 있나요?

0

93

2

카프카에서 발행한 이벤트를 처리중에 실패한 경우 보통 어떻게 처리하는지 궁금합니다

0

124

2

Kafka 비동기방식 적용하면서 질문 있습니다!

0

97

2

가용성에대한 질의..

0

76

2

궁금한게있어요..

0

90

2

MSA강의 보다 궁금해서 질문드립니다.

0

107

2