MySQL ‐ MySQL Lock Type - dnwls16071/Backend_Summary GitHub Wiki

📚 공유 락(Shared(S) Lock)

  • 공유 락(Shared Lock)은 읽기 락(Read Lock)이라고도 불린다.
  • 공유 락이 걸린 데이터에 대해서는 읽기 연산(SELECT)만 실행 가능하며, 쓰기 연산은 실행이 불가능하다.
  • 공유 락이 걸린 데이터에 대해서 다른 트랜잭션도 똑같이 공유 락을 획득할 수 있으나, 배타 락은 획득할 수 없다. 즉, 공유 락이 걸려도 읽기 작업은 가능하다는 뜻이다.
  • 공유 락을 사용하면, 조회한 데이터가 트랜잭션 내내 변경되지 않음을 보장한다.

📚 배타 락(Exclusive(X) Lock)

  • 배타 락은 쓰기 락(Write Lock)이라고도 불린다.
  • 데이터에 대해 배타 락을 획득한 트랜잭션은, 읽기 연산과 쓰기 연산을 모두 실행할 수 있다.
  • 다른 트랜잭션은 배타 락이 걸린 데이터에 대해 읽기 작업도, 쓰기 작업도 수행할 수 없다.
  • 즉, 배타 락이 걸려있다면 다른 트랜잭션은 공유 락, 배타 락 둘 다 획득 할 수 없다.
  • 배타 락을 획득한 트랜잭션은 해당 데이터에 대한 독점권을 갖는 것이다.

Hibernate 쿼리 실행 우선순위

  • JPA와 같은 ORM 프레임워크에서 쓰기 지연 저장소에 SQL 쿼리문을 적재하고 커밋이 되는 시점에 DB에 반영되는 것만 알고 있었는데 우선순위가 있다는 점은 처음 알게 되어 남겨놓는다.

📚 데드 락(Dead Lock)

  • 둘 이상의 프로세스가 다른 프로세스가 점유하고 있는 자원을 서로 기다릴 때 무한 대기에 빠지는 상황이다.
  • P1은 P2가 가지고 있는 자원이 해제되길 기다리고, P2는 P3가 가진 자원, 그 다음 ...과 같은 형식으로 가장 마지막의 프로세스 Pn가 P1이 가진 자원을 요청하고 해제되길 기다리는 형태이다.