Skip to content

MySQL ‐ MySQL Lock Type

dnwls16071 edited this page Aug 29, 2025 · 1 revision

📚 공유 락(Shared(S) Lock)

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

📚 배타 락(Exclusive(X) Lock)

  • 배타 락은 쓰기 락(Write Lock)이라고도 불린다.
  • 데이터에 대해 배타 락을 획득한 트랜잭션은, 읽기 연산과 쓰기 연산을 모두 실행할 수 있다.
  • 다른 트랜잭션은 배타 락이 걸린 데이터에 대해 읽기 작업도, 쓰기 작업도 수행할 수 없다.
  • 즉, 배타 락이 걸려있다면 다른 트랜잭션은 공유 락, 배타 락 둘 다 획득 할 수 없다.
  • 배타 락을 획득한 트랜잭션은 해당 데이터에 대한 독점권을 갖는 것이다.
  • JPA와 같은 ORM 프레임워크에서 쓰기 지연 저장소에 SQL 쿼리문을 적재하고 커밋이 되는 시점에 DB에 반영되는 것만 알고 있었는데 우선순위가 있다는 점은 처음 알게 되어 남겨놓는다.

📚 데드 락(Dead Lock)

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

📖 Java

📖 Kotlin

📖 Coroutine

📖 Spring

📖 Spring Security

📖 Spring Batch

📖 Reactive Programming

📖 Database

📖 MySQL

📖 Redis

📖 JPA

📖 QueryDsl

📖 MSA

📖 Kafka

📖 Apache Flink

  • [Apache Flink - Apache Flink Architecture]
  • [Apache Flink - Stream Processing]
  • [Apache Flink - Data Stream API & Window]
  • [Apache Flink - State Management]

📖 HTTP

📖 AWS

📖 Docker

📖 Kubernetes

📖 CI/CD

📖 Nginx

📖 Monitoring🥈

  • [Monitoring - Log Concept]
  • [Monitoring - Log Level & Filter]
  • [Monitoring - Logback]
  • [Monitoring - Log Collection with ELK Stack]
  • [Monitoring - Log Monitoring with Kibana]
  • [Monitoring - Building a Monitoring System with Spring Boot Actuator]
  • [Monitoring - Server Monitoring with Prometheus and Grafana with Discord Alerts]

📖 Test

📖 Effective Java 3/E

📖 Kotlin Academy - Effective Kotlin

📖 Kotlin Academy - 핵심편

📖 스프링으로 시작하는 리액티브 프로그래밍

📖 가상 면접 사례로 배우는 대규모 시스템 설계 기초 1

📖 가상 면접 사례로 배우는 대규모 시스템 설계 기초 2

📖 Clean Code

📖 리팩토링 2판

📖 주니어 백엔드 개발자가 반드시 알아야 할 실무 지식

📖 GraphQL

Clone this wiki locally