inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Hướng dẫn hoàn hảo về các mẫu thiết kế microservice

Mẫu CQRS

읽기 모델을 조회 최적화하여 성능 향상 하는 방법

76

YongIl Park

7 câu hỏi đã được viết

0

java spring-cloud 디자인-패턴 msa patterns

Câu trả lời 2

1

Dowon Lee

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

답변이 늦어 죄송합니다.

먼저, 질문1은, 아래 AI 답변에서도 언급 된 것처럼, 명령과 조회가 섞여 있는 경우, 데이터베이스 트랜잭션이 더 복잡해 질 수 있습니다. 하나의 스토리지에서 2가지 분리된 작업을 해야 하기 때문에, 확장성에도 적합하지 않을 수 있습니다. 조회는 트래픽이 많은데, 업데이트는 그렇지 않다고 할때, 조회만을 위해 확장해야 하는 경우도 생길 수 있습니다. 간단하게는 이러한 부분만 고려해 보더라도 최적화에 문제가 있을 수 있습니다.

질문2는, AI 답변에 아래 2가지 정도를 더 추가해 볼 수 있을 것 같습니다.

  1. 비동기 이벤트 스트리밍을 통한 "쓰기-조회" 간극 최적화

  2. 전문 검색 엔진(Full-text Search) 및 다중 투영(Multiple Projections): 예를 들어, 예를 들어, 상품 정보가 변경되었을 때 이를 일반 RDB 기반 조회 모델뿐만 아니라 Elasticsearch와 같은 검색 엔진에도 동시에 반영(Projection)합니다. 이는 검색 유연성이나 맞춤형 데이터 구조를 가져갈 수 있습니다.

추가 문의 사항 있으시면 글남겨 주세요.

감사합니다.

0

YongIl Park

답변 감사해요.

잘 배우고 있습니다.ㅎ

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. YongIl Park님께서 마이크로서비스 설계와 관련하여 CQRS 패턴에서 읽기 모델의 조회 최적화 방법에 대해 질문을 주셨군요.

질문 1: 섞여있으면 최적화를 못하나요?

CQRS(Command Query Responsibility Segregation) 패턴은 명령과 조회를 분리함으로써 더 나은 최적화를 가능하게 합니다. 명령과 조회가 섞여 있는 경우, 데이터베이스 트랜잭션이 더 복잡해지고, 하나의 데이터베이스 구조가 두 가지 요구사항을 동시에 만족시켜야 하므로 성능상의 제약이 생길 수 있습니다. 따라서 명령과 조회가 섞여 있으면 최적화가 어려워질 수 있습니다.

질문 2: 분리를 함으로써 가능한 최적화 방법

CQRS 패턴에서 명령과 조회를 분리함으로써 얻을 수 있는 최적화 방법은 다음과 같습니다:

  1. 스키마 최적화: 조회 모델을 read-heavy한 쿼리에 최적화된 스키마로 설계하여 빠른 검색 성능을 높일 수 있습니다.

  2. 데이터베이스 기술 선택: 조회 모델을 별도의 데이터베이스 인스턴스에 저장하여 각 데이터베이스에 맞는 최적화된 기술(예: NoSQL, 캐싱 기술 등)을 사용할 수 있습니다.

  3. 확장성 향상: 조회와 명령을 독립적으로 확장할 수 있으므로, 필요한 경우 더 많은 조회 작업을 효율적으로 처리할 수 있습니다.

  4. 캐싱 활용: 조회 데이터가 자주 변경되지 않는 경우, 캐싱을 통해 데이터 액세스 속도를 높일 수 있습니다.

추가로, 질문자님께 도움이 될 만한 유사 질문 및 답변이 있어 공유드립니다:

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

Entity 동등성 비교

0

4

1

패키지 구분에 대해 궁금한게 있습니다

0

13

1

안녕하세요. 바뀐 채점사이트 관련해서 문의드립니다.

0

19

1

갑자기 채점 사이트가 바뀌었어요

0

19

1

문제 리스트 페이지

0

22

1

part8 Notion 링크

0

23

1

채점 사이트 관련 질문드립니다

0

20

1

인텔리제이 MCP 서버 설정 관련

0

27

1

조회속도 개선에서 더 개선하는 방법이 궁금합니다.

0

29

2

필기자료 사라졌나요?(실기 일주일만에 안돼서 재도전-_-)

0

39

2

질문있습니다

0

26

1

1번 문제 질문입니다.

0

31

1

26년 1회 실기 해설 강의

0

51

2

음악플레이어 문제 중 코드질문

0

26

1

Orders에 테이블의 용도

0

65

2

MSA 아키텍쳐 프로젝트 구성 방식

0

94

2

마이크로서비스와 모듈러 아키텍처 선택 질문

0

66

2

섹션 2 - 12강 강의 제목 관련 질문있습니다.

0

62

1

실습 환경 구축에 대한 질문

0

65

2

k8s 를 고려한 개발은 어떻게 진행하나요?

0

96

2

gPRC 와 서비스 디스커버리에 대해 질문드립니다.

0

92

2

일부 강의가 재생이 되지 않습니다

0

123

2

https://github.com/joneconsulting/eshop 소스

0

153

2

강의 pdf교재는 별도로 없나요?

0

154

1