트랜잭션 ACID 원칙

2024. 11. 18. 17:36·DB
목차
  1. ACID 란?
  2. Atomicity - 원자성
  3. Consistency - 일관성
  4. Isolation - 독립성
  5. Durability - 영속성

ACID 란?

  • 트랜잭션이 반드시 지녀야하는 특징을 정해놓은 원칙이다.
    • 트랜잭션이란? 하나의 논리적 작업의 단위를 말한다.
  • ACID 원칙을 보장해야 DB 트랜잭션이 정상적으로 수행된다.
  • Atomicity(원자성), Consistency(일관성), Isolation(독립성), Durability(영속성) 으로 이루어져 있다.

 

Atomicity - 원자성

  • 원자성이란 변경사항이 모두 반영되거나, 아예 반영이 되지 않는 속성을 말한다.
  • 즉, 부분만 반영되는 것이 아닌 전부 커밋(commit)되거나 롤백(rollback)시키는 속성이다. -> 일부만 성공을 허용하지 않는다.
  • 개발자가 코드를 짜면 DBMS가 수행을 해주는 방식이다.

 

Consistency - 일관성

  • 트랜잭션 이전과 이후의 DB는 항상 일관돼야 한다는 원칙이다.
  • 즉, DB에 정의한 원칙을 위배하면 안 되는 원칙이다.
    • ex) 통장은 0원 미만으로 내려가면 안 된다. -> 계좌의 잔액이 마이너스가 될 수 없다.
  • DBMS가 이를 알아서 해주지만, 개발자도 항상 인지하고 있어야한다.

 

Isolation - 독립성

  • 독립성이란 하나의 트랜잭션 작업이 다른 트랜잭션의 작업에 영향을 주지 않는 원칙을 말한다.
  • DB는 다양한 Isolation level 정책을 제공하고, 개발자는 이를 바탕으로 락(공유 락, 배타 락)들을 이용하여 구현한다.
  • Isolation Level
    • Read Uncommitted : 커밋되지 않은 데이터를 읽는 level, 공유락과 배타락을 거의 사용하지 않는다. 
    • Read Committed : 커밋된 데이터만 읽기가 가능한 level
    • Repeatable Read : 같은 데이터를 여러번 읽어도 항상 같은 값을 반환한다. -> 트랜잭션이 종료되고 새로운 트랜잭션 조회시에 다른 데이터를 반환
    • Serialize : 모든 트랜잭션을 직렬적으로 수행

 

Durability - 영속성

  • 트랜잭션이 완료된 작업에 대해서 비활성 메모리에 저장되어 영구적으로 반영되어야 한다는 원칙이다.

'DB' 카테고리의 다른 글

이상 현상과 정규화  (2) 2024.11.19
낙관적 락 과 비관적 락  (0) 2024.11.18
인덱스 (index) (2)  (1) 2024.11.15
인덱스 (Index)  (1) 2024.11.15
순차 IO / 랜덤 IO  (0) 2024.11.14
  1. ACID 란?
  2. Atomicity - 원자성
  3. Consistency - 일관성
  4. Isolation - 독립성
  5. Durability - 영속성
'DB' 카테고리의 다른 글
  • 이상 현상과 정규화
  • 낙관적 락 과 비관적 락
  • 인덱스 (index) (2)
  • 인덱스 (Index)
CoMeangMeangIn
CoMeangMeangIn
코딩하는 코맹맹이
  • CoMeangMeangIn
    CoMeangMeangIn
    CoMeangMeangIn
  • 전체
    오늘
    어제
    • 분류 전체보기 (22)
      • java (3)
        • spring (1)
        • build (1)
      • DB (16)
      • 알고리즘 (1)
      • 회고 (1)
      • git (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.0
CoMeangMeangIn
트랜잭션 ACID 원칙
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.