inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

좋아요 수 설계 - 테이블 정의

좋아요 수 설계

해결된 질문

282

eoyeong

작성한 질문수 57

0

java mysql spring-boot kafka redis

답변 2

2

쿠케

eoyeong님, 안녕하세요!

설명이 일부 부족한 부분이 있었네요. 보충 설명 드립니다!

article insert 시점에는 어차피 좋아요 동작도 수행할 수 없으므로, 레코드 락이 충돌될 상황은 발생하지 않는게 맞습니다.

"쓰기 작업"이라는 용어 때문에 혼동이 있었을 것 같은데요,

"쓰기 작업"이라는 단어가 관점에 따라 생성/수정/삭제를 모두 포함하는 용어로 해석할 수 있기도 하지만, "게시글 수정 작업"이라는 용어로 표현하는게 더욱 명확했을 수도 있겠네요.

(DB 관점(?)에서는 읽기(READ), 쓰기(CREATE/UPDATE/DELETE)로 표현되기도 합니다!)

말씀하신대로 "게시글 수정 - 좋아요 수 업데이트"에 대한 상황이 맞습니다! (정확히는 삭제의 경우도 가능하겠네요)

 

혹시 더 궁금한 점 있으시면 편히 문의 주세요!

1

eoyeong

답변 감사합니다!!

주제가 게시글이라 말씀처럼 쓰기라는게 insert를 의미하는 걸로 혼동했네요 ㅎㅎ

강의 들으면서 많은 걸 배우고 있습니다 :)

0

인프런 AI 인턴

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

질문해주신 내용은 데이터베이스의 락(lock) 메커니즘과 관련이 있습니다. 특히나 데이터베이스에서의 쓰기와 갱신 작업이 서로에게 어떤 영향을 줄 수 있는지에 대한 부분인데요, 몇 가지 개념을 이해하시면 도움이 되실 것 같습니다.

X-Lock (Exclusive Lock)

  • X-Lock은 특정 레코드에 대한 배타적 잠금을 의미합니다. 즉, 이 잠금이 걸린 동안에는 해당 레코드에 대해 다른 트랜잭션이 읽기나 쓰기 작업을 수행할 수 없습니다.

Insert와 Update 간의 영향

  • 실무에서 insert 문과 update 문이 동시에 실행된다면, 각 트랜잭션이 서로 다른 레코드를 변경하는 경우에는 일반적으로 문제를 일으키지 않습니다.
  • 그러나, 같은 레코드에 대해 insert와 update가 동시에 실행되어야 한다면, 충돌이 발생할 수 있으며, 이 경우 데드락이나 병목 현상을 유발할 수 있습니다.

상관없는 락과 데이터 처리

  • 질문 내용에는 “상관 없는” 레코드에 대한 X-Lock의 문의가 포함되어 있습니다. 특정 레코드에 대한 잠금이 다른 레코드에서의 insert/updates에 직접 영향을 미치지 않는다는 것은 맞습니다. 그러나 이 경우 여전히 데이터베이스의 일관성과 무결성을 보장하기 위해 설계와 시행 착오가 필요할 수 있습니다.

관련 유사한 설명이나 질문에 대한 자세한 예제가 아래 게시글에서 다루어질 수 있습니다:
- 데이터베이스 락과 동시성 문제 해결 방법

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

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

0

32

1

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

0

49

2

게시글 테스트 데이터 삽입

0

51

2

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

0

104

2

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

0

98

2

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

1

138

2

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

0

92

2

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

0

61

1

조회수 조회 로직 질문

1

67

2

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

1

73

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

92

2

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

0

94

3

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

0

97

2

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

0

91

2

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

0

112

2

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

0

97

2

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

0

158

2