2022. 6. 25. 00:15ㆍTIL💡/Database
NHN 포스트에 상당히 잘 안내가 되어있어서 참고하면 좋다.
https://meetup.toast.com/posts/275
특징
- 도큐먼트 데이터베이스
- 도큐먼트는 필드와 값의 쌍으로 구성되며, 관계를 갖는 데이터를 중첩 도큐먼트와 배열을 사용해 1개의 도큐먼트로 표현
- 유연한 스키마
- 스키마의 선언 없이 필드의 추가와 삭제가 자유로운 Schema-less 구조이다.
- 컬렉션 내 모든 도큐먼트들의 필드 집합이 동일하지 않고 같은 필드라도 데이터 타입이 다를 수 있는 비정형 스키마
- 비관계형 데이터베이스
- RDBMS의 관계 개념이 없다.
- 조인을 지원하지 않는다. 대신 임베디드 방식의 도큐먼트 구조를 사용하거나 레퍼런스 방식의 도큐먼트 구조를 사용한 후 애플리케이션에서 조인
- 비트랜잭션
- mongoDB는 트랜잭션을 지원하지 않고 각각의 도큐먼트 단위로 처리
- 트랜잭션을 지원하지 않으므로 commit, rollback 개념이 없으며 auto commit으로 처리
데이터모델 🔥
mongoDB에서의 데이터 모델링은 업무 성격에 맞는 도큐먼트 구조의 설계가 중요하며 크게 임베디드 방식
과 레퍼런스 방식
으로 나뉜다.
임베디드 방식 | 레퍼런스 방식 |
관계를 갖는 데이터를 단일 도큐먼트에 저장하는 반정규화 모델 | 관계를 갖는 도큐먼트의 참조키를 저장하는 정규화 모델로 조인은 애플리케이션에서 처리해야 함 |
데이터 모델링🔥
데이터 모델링이란 업무 수행 시 발생하는 데이터를 정확하고 효율적으로 데이터베이스에 저장하기 위해 데이터 구조를 설계하는 과정이다.
이러한 데이터 모델링 개념에 mongoDB의 특성을 고려하여 데이터 구조를 설계하는 것을 mongoDB 데이터 모델링이라고 한다.
관계형 데이터베이스 데이터 모델링이 테이블 설계 후 칼럼을 설계하는 순서로 진행된다면, mongoDB 데이터 모델링은 도큐먼트 설계 후 컬렉션을 설계하는 순서로 진행된다. 또한 애플리케이션의 처리방안을 고려한 도큐먼트 구조를 어떻게 설계하느냐에 따라 데이터의 정합성과 성능에 큰 영향을 주게 되므로 이에 대한 정확한 이해가 필요하다.
임베디드 방식
임베디드 방식은 관계를 갖는 데이터 집합을 단일 도큐먼트에 포함하여 저장하는 방식으로 엑셀에서 학생정보와 학생이 수강하는 강의정보를 통합하여 1개의 시트로 관리하는 방식과 유사하다.
항목 | 내용 |
설명 | - 임베디드 방식은 강의 정보처럼 동일한 데이터를 각 학생 도큐먼트에 저장하여 구조를 단순화하는 반정규화 모델 - 임베디드 방식은 조회 성능이 좋고 도큐먼트에 포함된 관련 데이터를 모두 업데이트할 수 있음 - 데이터 관리가 직관적이고 쿼리가 단순함 |
문제점 | - 데이터 중복은 도큐먼트 구조를 단순화하고 조회 성능을 향상하나 데이터 불일치가 발생할 수 있음 - 도큐먼트에 포함하는 데이터가 증가할수록 도큐먼트의 크기도 증가하여 디스크 I/O 시 성능 저하 발생 및 도큐먼트의 최대 크기를 초과 시 저장이 불가능할 수 있음 - 데이터의 관계가 복잡하거나 계층 구조를 갖는 업무는 관리가 어려움 |
권장 업무 | - 조회 성능이 중요하고 데이터 중복에 따른 데이터 불일치 문제가 발생하지 않는 업무 - 업데이트가 발생하지 않는 업무 |
레퍼런스 방식 - 기본
레퍼런스 방식은 도큐먼트에 관계를 갖는 다른 도큐먼트의 식별자를 참조키로 저장하여 필요 시 애플리케이션에서 조인하는 방식
항목 | 내용 |
설명 | - 레퍼런스 방식은 데이터가 중복되지 않도록 업무 성격별로 컬렉션을 분리 후 참조하므로 데이터 불일치가 발생하지 않는 정규화 모델임 - 적절한 업무 단위의 컬렉션으로 데이터가 분리되어 임베디드 방식 대비 도큐먼트의 크기 증가가 작음 - 업무 요건 추가 및 변경으로 인한 도큐먼트 구조에 미치는 영향이 적음 |
문제점 | - 참조가 많은 도큐먼트 또는 대규모 도큐먼트를 조회하는 경우 애플리케이션에서 2차 쿼리로 인한 처리량 증가로 조회 성능이 저하될 수 있음 - 데이터 중복에 의한 데이터 일관성 문제는 해소되나 참조 정보를 정확하게 관리하지 않는 경우 참조 정보 소실에 의한 데이터 정합성 문제가 발생할 수 있음 |
권장 업무 | - 조회 성능보다는 데이터 무결성이 중요한 업무 - 임베디드 방식으로 사용 시 디스크 I/O 성능에 문제가 예상되는 업무 - 데이터의 관계가 복잡하거나 계층 구조를 갖는 업무 |
레퍼런스 방식 - 세부 레퍼런스 방식
항목 | 내용 |
자식 참조 | - 부모 도큐먼트에서 관계를 갖는 자식 도큐먼트의 식별자를 참조키로 저장하는 방식임 - 부모 도큐먼트와 관계를 갖는 자식 도큐먼트를 쉽게 찾을 수 있으며 참조 정보가 부모 도큐먼트에만 존재하므로 관리가 편리함 - 부모 도큐먼트에 업데이트가 집중되어 성능 문제가 발생할 수 있으며 자식 도큐먼트가 많은 경우 도큐먼트의 최대 크기를 초과할 수 있음 - 부모 도큐먼트에 발생하는 부하 및 크기 증가를 고려하여 자식 도큐먼트가 적게 생성되는 업무에 적합함 |
부모 참조 | - 자식 도큐먼트에서 관계를 갖는 부모 도큐먼트의 식별자를 참조키로 저장하는 방식임 - 자식 도큐먼트에서 부모 도큐먼트를 쉽게 찾을 수 있으며 자식 도큐먼트의 추가 및 삭제로 인한 부모 도큐먼트의 업데이트가 없음 - 부모 도큐먼트와 관계를 갖는 모든 자식 도큐먼트 조회 시 소요시간이 증가할 수 있음 - 이력 또는 로그 데이터와 같이 자식 도큐먼트가 많이 생성되는 업무에 적합함 |
상호 참조 | - 관계를 갖는 부모 도큐먼트와 자식 도큐먼트가 각각 서로의 식별자를 참조키로 저장하는 방식임 - 부모 도큐먼트에서 자식 도큐먼트를 찾거나 자식 도큐먼트에서 부모 도큐먼트를 쉽게 찾을 수 있으나 다른 방식에 비해 참조 정보 관리가 어려움 - 부모 도큐먼트와 자식 도큐먼트 모두 업데이트가 과도하게 발생할 수 있으며 참조 정보 관리 부주의 시 데이터 정합성 문제가 쉽게 발생할 수 있음 - 데이터 변경이 적고 부모 도큐먼트와 자식 도큐먼트가 서로를 빈번하게 참조하는 업무에 적합함 |
컬렉션
컬렉션은 관계형 데이터베이스의 테이블과 같은 개념으로 용도가 가턱나 유사한 도큐먼트들의 그룹을 묶는 단위를 의미하며, 4ㅏ가지 종류의 일반 컬렉션, 캡드 컬렉션, TTL 컬렉션, 시스템 컬렉션으로 나뉜다.
항목 | 내용 |
일반 컬렉션 | - 가장 일반적으로 사용되는 컬렉션 |
캡드 컬렉션 | - 캡드 컬렉션은 고정된 크기를 갖는 컬렉션으로 높은 성능의 로깅 기능을 위해 설계됨 - 명령어: db.createCollection("log"\, {capped: true, size: 1000000, max: 100}) 1) "log" 컬렉션 생성 시 캡드 옵션을 설정하고 최대 사이즈와 최대 도큐먼트 수를 설정함 2) size: 최대 저장 크기로 단위는 Byte임 3) max: 최대 도큐먼트 수로 옵션 생략이 가능함 - 도큐먼트 추가 시 디스크 공가닝 없는 경우 가장 오래 전에 추가된 도큐먼트로부터 덮어쓰기함 - 오래된 데이터를 수동으로 삭제하는 작업을 없애 데이터 관리가 편리함 - 로깅을 위해 만들어져 사용자가 임의로 삭제하거나 업데이트할 수 없음 |
TTL 컬렉션 | - TTL 컬렉션은 특정 시가닝 경과한 도큐먼트를 자동으로 삭제하는 컬렉션으로 TTL 인덱스에 의해 지원됨 - 명령어: db.member.createIndex({ modify_date: 1}\, { expireAfterSeconds: 3600 }) 1) modify_date 필드에 인덱스를 생성하여 1시간(3600/60/60)이 지난 도큐먼트는 삭제함 2) expireAfterSeconds: 도큐먼트의 유지시간을 초단위로 설정함 - "_id"필드 또는 이미 다른 인덱스가 있는 필드는 TTL 인덱스를 가질 수 없음 - 캡드 컬렉션인 경우 TTL 인덱스를 가질 수 없음 - 단일 인덱스만 사용 가능하며 복합 인덱스를 가질 수 없음 |
시스템 컬렉션 | - mongoDB 내부에서 사용되는 컬렉션으로 사용자가 지정하여 사용할 수 없음 |
데이터 모델링 절차
mongoDB 데이터 모델링은 다음과 같은 절차로 진행된다.
- 요구사항 수집: 사용자가 시스템에서 요구하는 정보를 수집함
- 업무 데이터 분석: 업무 데이터의 발생 규칙과 관계 및 서비스에 대한 정보를 분석함
- 도큐먼트 설계: 분석된 업무 데이터를 기반으로 애플리케이션의 처리 방안과 읽기 미 ㅊ업데이트 성능 등을 고려하여 도큐먼트를 설꼐함
- 컬렉션 설계: 컬렉션명 부여 및 적절한 컬렉션 종류를 선택함
'TIL💡 > Database' 카테고리의 다른 글
[MongoDB] Index의 자료구조는 무엇일까? B-Tree (0) | 2022.10.15 |
---|---|
[Python] Celery로 비동기 실시간 데이터 적재 및 분석 처리 (0) | 2022.09.09 |
SQL 가독성을 높이는 다섯 가지 사소한 습관 (0) | 2022.06.10 |
[SQL] FROM절 JOIN 형태 (0) | 2022.03.29 |
[EF Core]Entity Framework core (0) | 2022.03.13 |