Skip to main content

Command Palette

Search for a command to run...

[Spring] ACID 격리성

Updated
2 min read
[Spring] ACID 격리성
S

Nice to meet u :) Im Backend Developer

목표 : 트랜잭션의 ACID 속성 중 격리성(Isolation)이 보장되지 않을 때 발생할 수 있는 문제점, 이를 해결하기 위한 트랜잭션 격리 수준확인하기.

1️⃣ 격리성이 보장되지 않는다면 ?

격리성은 동시에 실행되는 트랜잭션들이 서로 영향을 미치지 않도록 보장하는 것을 의미한다. 격리성이 보장되지 않는다면 총 3가지의 문제가 발생한다.

  1. Dirty Read

    한 트랜잭션이 아직 커밋되지 않은 데이터를 다른 트랜잭션이 읽어가는 현상이다.

    • 트랜잭션 A가 데이터를 수정한 후 커밋하지 않고 롤백함.

    • 이때 트랜잭션 B는 A가 롤백 전 변경한 데이터를 읽음.

잘못된 임시 데이터가 사용되어 데이터 불일치가 발생할 수 있다.

  1. Non-Repeatable Read

    하나의 트랜잭션 내에서 동일한 데이터를 여러 번 읽을 때, 읽을 때마다 결과가 달라지는 현상이다.

    • 트랜잭션 A가 같은 데이터를 여러 번 조회 중임.

    • 그 사이 트랜잭션 B가 데이터를 수정하고 커밋함.

    • 이후 트랜잭션 A는 다시 조회했을 때 처음과 다른 결과를 얻음.

일관되지 않은 데이터가 조회되어 문제가 될 수 있다.

  1. Phantom Read

    한 트랜잭션 내에서 같은 조회 조건으로 데이터를 반복 조회할 때, 이전에 없던 새로운 데이터(팬텀)가 갑자기 나타나는 현상입니다.

    • 트랜잭션 A가 특정 조건으로 데이터를 여러 번 조회함.

    • 그 사이 트랜잭션 B가 새로운 데이터를 추가하고 커밋함.

    • 이후 트랜잭션 A가 다시 조회 시 이전에 없던 데이터가 나타남.

데이터가 일관되게 유지되지 않아 신뢰성에 문제가 생깁니다.


2️⃣ 격리성 수준

여러 트랜잭션이 동시에 실행될 때 데이터의 일관성을 어떻게 유지할지 결정한다.

  1. DEFAULT

    사용하는 데이터 기술 또는 DB 드라이버의 디폴트 설정을 따른다.

  2. READ_UNCOMMITTED

    가장 낮은 격리수준이다.

    하나의 트랜잭션이 커밋되기 전에 그 변화가 다른 트랜잭션에 그대로 노출되는 문제가 있다. 위 3가지 문제가 모두 발생한다.

  3. READ_COMMITED

    가장 많이 사용하는 격리수준이다. 데이터가 변경되는 동안은 조회할 수 없다. Dirty Read를 방지한다. commit후에 변경된 값을 갖고온다.

  4. REPEATABLE_READ

    하나의 트랜잭션이 읽은 데이터를 다른 트랜잭션이 수정할 수 없도록 막아준다. 트랜잭션 내에서 한번 조회한 데이터를 반복해서 조회해도 같은 데이터가 조회된다. 즉 조회한 데이터 내용의 동일함을 보장한다.

  5. SERIALIZABLE

    가장 강력한 트랜잭션 격리 수준으로, 트랜잭션을 순차적으로 진행시켜준다. 여러 트랜잭션이 동시에 같은 테이블의 정보를 액세스할 수 없다. SERIALIZABLE은 가장 안전하지만 가장 성능이 떨어지는 격리수준이다.

출처

https://mangkyu.tistory.com/169 [MangKyu's Diary:티스토리]

https://velog.io/@jurlring/MySQL%EC%9D%98-%ED%8A%B8%EB%9E%9C%EC%9E%AD%EC%85%98-%EA%B2%A9%EB%A6%AC-%EC%88%98%EC%A4%80%EA%B3%BC-%EC%8A%A4%ED%94%84%EB%A7%81%EC%9D%98-Transactional-%EA%B8%B0%EB%B3%B8-%EA%B2%A9%EB%A6%AC-%EC%88%98%EC%A4%80

More from this blog

[Spring] N+1문제 발생과 분석

✍️ 작성하게 된 이유 옷을 관리하는 서비스를 개발하면서 Cloth 엔티티와 그에 연관된 ClothWithAttributes, Attribute 데이터를 함께 조회하는 기능이 필요했다.그런데 연관 데이터를 조회할 때마다 쿼리가 폭발적으로 증가(N+1 문제) 하며, 성능이 급격히 저하되는 상황을 마주하게 되었다. Spring JPA의 대표적인 문제로 N+1임을 알고있었지만, 해결하는 방법은 Fetch Join밖에 몰랐다. 지연로딩되는 필드를 엔티...

Sep 17, 20256 min read
[Spring] N+1문제 발생과 분석

데이터베이스 기본 개념 정리

1️⃣ 데이터베이스(DB) & DBMS DB (Database): 일정한 규칙(스키마)에 따라 구조화되어 저장된 데이터의 집합. DBMS (Database Management System): DB를 제어/관리하는 시스템 소프트웨어. 특징: 실시간 접근 가능, 동시 공유 가능. 구조: 데이터베이스 → DBMS → 응용 프로그램 → 사용자 2️⃣ 엔티티(Entity) & 릴레이션(Relation) 엔티티: 여러 속성을 가진 "개체"...

Aug 5, 20252 min read
데이터베이스 기본 개념 정리

[Project] 날씨에 맞는 옷 추천 서비스 : 지그재그 크롤링 여정 기록 (1) ChromeDriver를 EC2에 설치하기

✍️ 작성하게 된 이유 무신사, 29cm는 Jsoup으로 충분히 크롤링이 가능했기 때문에, ZigZag도 당연히 Jsoup으로 처리될 것이라 생각했다. 무신사, 29cm와 마찬가지로 필요한 데이터는 모두 <script> 태그 안에 들어있었다. 하지만… 예상은 보기 좋게 빗나갔다. 🧪 현상 ✅ 로컬 크롤링 → 정상 작동 Jsoup으로 script 태그 내에서 대표 이미지와 상품명을 잘 추출 로컬 환경에서는 아무 문제 없이 작동 ❌ A...

Jul 30, 20253 min read
[Project] 날씨에 맞는 옷 추천 서비스 : 지그재그 크롤링 여정 기록 (1) ChromeDriver를 EC2에 설치하기

[Project] 날씨에 맞는 옷 추천 프로젝트: Selenium은 정말 필요한 선택이었을까? - 크롤링 삽질 기록

✍️ 작성하게 된 이유 날씨에 따라 옷을 추천해주는 서비스를 만들면서, 사용자가 입력한 구매 링크에서 옷 정보( 대표이미지, 상품명 )를 불러오는 기능이 필요했다. 처음에 해당 페이지를 동적 페이지로 판단했고, 자연스럽게 Selenium을 도입했다. 하지만 이 결정이 과연 최선이었는지는 수많은 시행착오 끝에야 알 수 있었다. 🕸️ Selenium을 선택한 이유 동적 페이지는 Jsoup으로 크롤링이 어렵다는 인식으로 처음부터 Selenium을 ...

Jul 28, 20254 min read
[Project] 날씨에 맞는 옷 추천 프로젝트: Selenium은 정말 필요한 선택이었을까? - 크롤링 삽질 기록

Soyulia's Blog

49 posts