inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링부트로 직접 만들면서 배우는 대규모 시스템 설계 - 게시판

댓글 최대 2 depth - CUD API 구현

댓글 최대 2depth - CUD API 구현에서 질문 있습니다.

해결된 질문

119

작성자 없음

작성한 질문수 0

1

안녕하세요 선생님 좋은 강의 해주셔서 감사합니다.

댓글 create 구현에서 findParent() 함수를 구현할때,

.filter(Comment::isRoot)

이런 코드가 있는데, 애초에 parentCommentId 에 root 댓글이 아닌 댓글의 ID가 존재하면 안되는 것 아닌가요 ?


존재하면 안되는 경우를 filter 로 걸러주는 것 같아서 필요한 코드인지 의문이 들어 질문 남깁니다.

java mysql spring-boot kafka redis

답변 2

1

쿠케

태우님, 안녕하세요!

 

request.parentCommentId는 클라이언트한테 전달받는 값입니다.

클라이언트가 parentCommentId에 1뎁스 댓글 ID를 전달한다고 기대할 뿐이지,

해당 값이 반드시 부모 댓글 ID라는 것을 보장할 수 없습니다.

parentCommentId에 2뎁스 댓글 ID를 전달하면, 신규 생성 건은 3뎁스 댓글로 만들어질 수 있으므로 최대 2뎁스 규칙에 대한 보장이 깨지게 되는 것입니다.

이러한 검증을 위한 방어 로직이라고 봐주시면 될 것 같네요!

0

인프런 AI 인턴

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

질문해주신 댓글 작성 관련 구현 사항은 대규모 시스템에서의 댓글 트리 구조와 데이터 일관성 유지에 관한 것입니다. findParent() 함수에서 filter(Comment::isRoot) 를 사용하는 이유는 다음과 같습니다.

findParent() 함수의 의도와 동작

  1. 데이터 검증 및 보호:

    • filter(Comment::isRoot) 는 부모 댓글이 반드시 루트 댓글이어야 한다는 조건을 강제합니다. 이 코드를 통해 root 댓글이 아닌 경우를 필터링하여, 시스템 내에서 논리적인 일관성을 유지할 수 있습니다.
  2. 잘못된 데이터 접근 방지:

    • 실수로 부모 댓글을 지정하는 과정에서 잘못된 ID(루트 댓글이 아닌)를 지정할 수 있습니다. 이러한 경우를 미리 방지하여 데이터베이스에 잘못된 상태가 저장되지 않도록 보장합니다.
  3. 시스템 안정성 및 유지보수성 확보:

    • 잘못된 데이터가 입력되었을 경우 시스템에 발생할 수 있는 잠재적인 오류를 예방하고, 정확한 트리 구조를 유지하기 위해 이러한 필터링 과정을 추가합니다. 이를 통해 코드의 안정성과 유지 보수성을 확보할 수 있습니다.

이런 체크는 비즈니스 로직이 변경되거나 향후 최적화 과정에서도 데이터의 일관성을 보장하는 데 중요한 역할을 합니다.

관련된 유사한 질문의 사례를 참고하고자 한다면 아래의 URL을 확인하시면 좋을 것 같습니다:
- 댓글 트리의 일관성 및 데이터 검증 방법 (게시글 제목)

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

@Version 어노테이션이 붙은 필드는 낙관적 락이든 비관적 락이든 업데이트가 됩니다.

0

31

1

consumer에서 에러가 발생할 경우 데이터 유실 문의

0

47

2

게시글 테스트 데이터 삽입

0

51

2

정렬, 필터, 검색 등의 조건이 붙을 경우 최적화할 수 있는 방법이 무엇이 있을까요?

0

104

2

좋아요 기능 정합성 보장 방법

0

98

2

좋아요 동시성처리 최적의 선택?

1

136

2

프론트엔드 msa 환경 api 주소 통합? 과 서버끼리 통신 방식에대해

0

92

2

안녕하세요 무한스크롤 강의듣다가 질문이 있습니다.

0

59

1

조회수 조회 로직 질문

1

67

2

비로그인 유저도 어뷰징 방지 정책

1

72

2

CommentServiceTest의 테스트 로직 질문

0

54

2

무한 스크롤 방식에서 페이지 번호 방식 쿼리의 문제점 의문

1

74

2

path 쿼리 관련 질문드립니다!

0

60

2

antigravity 에디터를 쓰신다면 종료해주세요

1

123

0

프로젝트 구조

0

88

2

article_like_count api test

0

79

2

이벤트 페이로드 객체의 생성 방식이 팩토리 메서드 패턴이 아닌 빌더 패턴인 이유가 궁금합니다!.

0

104

2

[33. 좋아요 수 구현] 에서 테스트 하는 화면 동시성 문제

0

91

2

findByPath에서 articleId로도 검색을 해야 할 것 같아요.

0

92

3

jpa ddl-auto none을 하는 이유와 join 방법

0

97

2

팩터리 메소드와 response 객체 사용 이유가 궁금합니다!

0

90

2

커서 기반 페이지네이션 과 무한 스크롤링

0

110

2

게시글 생성 로직에서 오류 발생시 redis 게시글 수 되돌리기

0

97

2

멀티 모듈이 아닌 MSA 환경에서 common

0

156

2