Hyemi Lee

Hyemi Lee

주니어 개발자의 삽질과 기록

DATABASE, MySQL 스토리지 엔진

MySQL DB엔진

스토리지엔진

  • 스토리지엔진은 DB에서 데이터를 어떤 방식으로 저장하고, 접근할 것인지에 대한 기능을 제공한다
  • 스토리지엔진의 특성에 따라 데이터 접근이 얼마나 빠른지, 얼마나 안정적인지, 트랜잭션 등의 기능을 제공하는지 등의 차이점이 발생한다.
  • 1대의 서버에 두가지 스토리 엔진을 혼용하는것은 좋지 않다.
    • 각기 다른 동작, 메모리 사용법을 취하므로
    • 혼용하면 효율적인 cpu, 메모리 사용이 어렵다

효과적인 스토리 엔진 선택

스토리 엔진 엑세스 패턴
MyISAM 추가 처리만 한다, select count(*) 를 많이 사용
InnoDB 갱신 빈도가 높다, 트랜잭션이 필요하다, 민감한 정보를 사용한다

1. MyISAM

  • MySQL 5.5 이전까지 기본 스토리지 엔진
  • Table-level Lock
    • 테이블 작업시 특정 행을 수정하려고 하면 테이블 전체에 락이 걸린다
  • 트랜잭션 미지원
    • 작업도중 문제가 발생해도, 이미 db안으로 데이터가 입력됨
  • select작업이 많은 경우 효과적
    • 잦은 변경 및 삭제에는 성능이 좋지 못함.

2. InnoDB

  • MySQL 5.5 부터 기본 스토리지 엔진
  • 트랜잭션 지원 (ACID Transaction)
  • MyISAM 보다 data 저장 비율이 낮고, 데이터 로드 속도 느리다.
  • Row-level Lock
    • 테이블작업시, 작업 시작하면 해당 row만 잠긴다.
    • insert, update, delete에 대한 속도가 빠르다
  • 민감한 정보를 갖는 table(회원 table, 돈 관련 table)에 사용하기 좋다
    • 비정상 종료시 복구 기능
  • 주로 데이터 입력 및 수정이 빈번한 높은 퍼포먼스를 요구하는 대용량 사이트에 적합

3. Cluster(NDB)

  • 트랜잭션 지원
  • 모든 데이터와 인덱스가 메모리에 존재하여 매우 빠른 데이터 로드 속도
  • PK사용시 최상의 속도를 나타낸다

4. Archive

  • MySQL5.0 부터 새롭게 도입된 엔진
  • 자동으로 데이터 압축지원
  • 다른 엔진에 비해 80% 저장 공간 절약 효과
  • 가장 빠른 데이터 로드 속도
  • insert, select만 가능

5. Federated

  • MySQL5.0 부터 새롭게 도입된 엔진
  • 물리적 db에 대한 논리적 db를 생성하여 원격 데이터 컨트롤 가능
  • 실행속도는 N/W요소에 따라 좌우된다
  • 테이블 정의를 통한 SSL보안 처리
  • 분산 DB환경에서 사용

참고

Tags:

Categories:

Updated:

Share on

Twitter Facebook LinkedIn

You may also enjoy

Redis Stream

2021年04月28日

Stream Stream은 로그 데이터를 처리하게위해 5.0에서 새로 도입된 데이터 타입입니다. 대량의 데이터가 연속적으로 발생할때 처리하기 위해 등장했습니다. 기존 데이터를 수정하지 않고 오직 추가로 발생합니다. 이런 종류의 데이터를 stream or log데이터...

Study, Object, chapter2&3 presentation

2021年04月20日

chapter03. 역할, 책임, 협력 객체지향 설계란, 올바른 객체에게 올바른 책임을 할당하면서 낮은 결합도와 높은 응집도를 가진 구조를 창조하는 활동이다.

Spring, chatting 프로그램 만들기, Reactive란?

2020年06月16日

Reactive 막힘없이 흘러다니는 data(event)를 통해 사용자에게 자연스러운 응답을 주고 규모 탄력적으로 리소스를 사용하며 실패에 있어서 유연하게 대처한다 모든 지점에서 블럭 되지 않게 하자 oop와 같은 패러다임 모든 것을 비동기적인 data의 strea...