NoSQL MongoDB : 기본 구조

2020.09.30 21:05

졸리운_곰 조회 수:23

MongoDB : 기본 구조

DB internal structure

 

 

  • MongoDB의 데이터 저장소는 메모리 맵 파일(Memory Mapped File)을 사용한 가상 메모리를 사용한다

  • MongoDB의 데이터 구조 : 데이터를 저장 : Record // 인덱스를 저장 : Bucket
    • Record : BSON 객체를 저장하는 노드를 레코드로 정의, Record는 BSON 객체의 이중연결리스트 (double linked list)구조로 구성
    • Bucket : 인덱스는 레코드에 저장된 데이터를 빠르게 찾기 위해 b-tree 형태로 저장된 노드 구조를 가짐
    • b-tree 노드를 버켓(Bucket)이라고 정의
  • Extent : MongoDB는 대용량 데이터를 HDD에 쉽게 저장할 수 있는 단위로 레코드들을 grouping한다.
    • 이를 Extent라고 한다. Hadoop에서 chunk라고 하는 느낌이라고 생각하면 된다.
    • Extent 들을 이용하여 MongoDB는 HDD에 저장될 파일과 삭제된 레코드를 관리한다.
    • 자료 구조 관점에서 보면 연결되어 있는 Record들의 Header 역할을 수행하는 것
  • 사용자가 하나의 데이터베이스를 만들었다면, MongoDB는 데이터베이스와 관련된 한 개의 네임스페이스(DB Namespace)를 만든다.
  • DB Namespace == 컬렉션 (collection Namespace) + Free Extent 리스트(DB에서 삭제된 레코드 리스트를 가지고 있는 Extent 리스트)
  • Collection Namespace는 primary index Namespace(B Tree)와 Record Extent list를 가진다. 그래서 MongoDB가 search가 빠른이유이다. primary index namespace에서 이진트리로 찾아내기 때문이다.
  • 만약 Primary index 이외에 추가로 필드를 가지고 인덱스를 더 생성하면 B Tree 형태의 Index Namespace를 하나 더 가진다.

    경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
    어린이용이며, 설치가 필요없는 브라우저 게임입니다.
    https://s1004games.com

  • Write(insert/update)를 수행할 때, MongoDB는 해당 레코드가 가리키는 가상 메모리 주소 공간에 데이터를 적재한다.
  • Read를 수행할 때, MongoDB는 해당 메모리 주소 공간에 할당된 데이터가 가상 메모리에 로딩되어 있는지 확인하고, 없다면 파일에서 내용을 읽어 가상 메모리에 적재한다.
  • MongoDB는 백그라운드로 (주기적으로)가상 메모리에 적재된 데이터를 HDD에 최대 2GB 단위로 파일을 구성한 볼륨(volume)으로 HDD에 데이터를 flush한다.

정리

  1. 처음 DB를 생성하면 DB Namespace가 형성이 되고, Collection Namespace와 Free Extent List가 형성이 된다. Collection Namespace는 primary index namespace 와 Record Extent list로 구성이 되어있다. Primary index namespace는 이진트리로 구성되어있어 굉장히 탐색이 빠르다. 따라서 다른 index로 search 하고 싶을 때는 index namespace를 하나 더 추가하면 된다.
  2. function, read을 작동하면 primary index namespace를 통해 search를 한다. 그리고 해당 record 주소 공간에 할당된 데이터가 있다면 불러오고, 아니면 file에서 content를 읽어와 가상 메모리에 적재를 한다.
  3. function, write를 작동하면 해당 record가 가리키는 가상메모리 주소 공간에 데이터를 적재한다.

출처 : https://nicewoong.github.io/development/2018/02/10/mongodb-internal/



출처: https://mambo-coding-note.tistory.com/339 [화학쟁이의 ㎚코딩도장]

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
공지 오라클 기본 샘플 데이터베이스 졸리운_곰 2014.01.02 25085
공지 [SQL컨셉] 서적 "SQL컨셉"의 샘플 데이타 베이스 SAMPLE DATABASE of ORACLE 가을의 곰을... 2013.02.10 24564
공지 [G_SQL] Sample Database 가을의 곰을... 2012.05.20 25943
» MongoDB : 기본 구조 file 졸리운_곰 2020.09.30 23
804 [tensorflow] 텐서플로로 음악 작곡 : Generate Music in TensorFlow 졸리운_곰 2020.09.27 57
803 한국어 BERT, HanBert를 소개합니다. file 졸리운_곰 2020.09.25 421
802 [mongodb] SQL to Aggregation Mapping Chart 몽고디비 SQL 쿼리 매핑 졸리운_곰 2020.09.23 95
801 한국어 자연어 처리 데이터셋 목록 file 졸리운_곰 2020.09.20 695
800 초간단 Mongo DB Quick Start Guide file 졸리운_곰 2020.09.20 19
799 Getting started with Apache Kafka in Python file 졸리운_곰 2020.09.10 58
798 데이터 입력/수정/삭제를 한 번에 처리할 수 있는 MERGE에 대해 알아보자 file 졸리운_곰 2020.09.10 63
797 Oracle :: MERGE INTO 졸리운_곰 2020.09.10 19
796 오라클 MERGE INTO - 한번에 INSERT, UPDATE 하기 졸리운_곰 2020.09.10 56
795 Oracle Merge 명령어 사용 file 졸리운_곰 2020.09.10 16
794 Google Colab 사용하기 file 졸리운_곰 2020.09.08 2120
793 [Kafka] 다운로드 및 Quick Start file 졸리운_곰 2020.09.07 35
792 [Kafka] 기본 개념잡기 file 졸리운_곰 2020.09.07 29
791 설문 조사를위한 데이터베이스 설계 file 졸리운_곰 2020.09.05 3363
790 Deep Learning (Keras) Models Deployment using SQL databases file 졸리운_곰 2020.08.04 45
789 Deep Learning (Keras) Models Deployment using SQL databases 졸리운_곰 2020.08.04 93
788 ubuntu에서 pytorch gpu 버전 설치 과정 정리 file 졸리운_곰 2020.07.28 33
787 [dbguide] 프로세스모델링 작성 절차 (데이터베이스 시스템분석설계 프로세스 모델링) file 졸리운_곰 2020.07.27 312
786 [dbguide] 데이터모델링 작성 절차 (데이터베이스 모델링 절차) file 졸리운_곰 2020.07.27 302
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED