간편결제, 신용카드 청구할인
카카오페이 3,000원
(카카오페이 5만원 이상 결제시, 5/1~5/31 기간 중 1회)
우리카드 3천원/7천원/1만 5천원 즉시할인
3만원/5만원/10만원 이상 결제시
삼성카드 6% (40,610원)
(삼성카드 6% 청구할인)
인터파크 롯데카드 5% (41,040원)
(최대할인 10만원 / 전월실적 40만원)
북피니언 롯데카드 30% (30,240원)
(최대할인 3만원 / 3만원 이상 결제)
NH쇼핑&인터파크카드 20% (34,560원)
(최대할인 4만원 / 2만원 이상 결제)
Close

Real MongoDB : 대용량 데이터 처리를 위한

소득공제

2013년 9월 9일 이후 누적수치입니다.

판매지수 878
?
판매지수란?
사이트의 판매량에 기반하여 판매량 추이를 반영한 인터파크 도서에서의 독립적인 판매 지수입니다. 현재 가장 잘 팔리는 상품에 가중치를 두었기 때문에 실제 누적 판매량과는 다소 차이가 있을 수 있습니다. 판매량 외에도 다양한 가중치로 구성되어 최근의 이슈도서 확인시 유용할 수 있습니다. 해당 지수는 매일 갱신됩니다.
Close
공유하기
  • 저 : 이성욱
  • 출판사 : 위키북스
  • 발행 : 2018년 01월 30일
  • 쪽수 : 920
  • 제품구성 : 전1권
  • ISBN : 9791158390921
정가

48,000원

  • 43,200 (10%할인)

    2,400P (5%적립)

할인혜택
적립혜택
  • I-Point 적립은 출고완료 후 14일 이내 마이페이지에서 적립받기한 경우만 적립됩니다.
추가혜택
배송정보
주문수량
감소 증가
  • 이벤트/기획전

  • 연관도서(15)

  • 사은품(3)

출판사 서평

MongoDB의 "Know-How"가 아닌 "Know-Why"를 전달해 드립니다!

MongoDB 메뉴얼은 아주 간결하고 기본적인 내용에 충실하게 작성되어 있다. 하지만 문법이나 명령만으로는 DBMS를 사용할 수 없다. 내부 작동 방식을 모르면 수많은 시행착오를 거치게 되며, 이런 시행착오는 결국 서비스 품질 저하로 연결될 것이다. 이 책에서는 MongoDB 서버를 사용하는 데 꼭 필요한 아키텍처와 함께 MongoDB 내부(Internal)에 대해 자세히 설명하고 있다. 또한 다양한 시행 착오를 줄이기 위한 주의 사항들에 대해서도 설명한다. 이 책은 MongoDB 서버(특히 MongoDB 1.x와 2.x 버전)에 실망했던 독자들에게 다시 한 번 MongoDB 서버의 가능성을 보여주고, 새로운 DBMS 솔루션을 찾고 있는 독자들에게 대안을 제시해 줄 것이라 생각한다.

* 이 책에서 다루는 내용 *

- 데이터베이스 트렌드
- MongoDB 복제와 샤딩
- WiredTiger 스토리지 엔진의 내부 구조와 작동 방식
- MongoDB 인덱스와 쿼리 튜닝
- 한글 전문 검색과 위치 기반 검색
- MongoDB의 잠금과 트랜잭션
- 운영을 위한 보안과 백업

목차

01장: MongoDB
1.1 데이터베이스 트렌드
1.2 MongoDB의 라이선스
1.3 MongoDB 버전
- 1.3.1 setFeatureCompatibilityVersion 옵션
1.4 MongoDB vs. RDBMS(MySQL)
1.5 MongoDB vs. NoSQL(HBase)
1.6 MongoDB 아키텍처
1.7 MongoDB 배포 형태
- 1.7.1 단일 노드(Standalone)
- 1.7.2 단일 레플리카 셋(Single Replica-set)
- 1.7.3 샤딩된 클러스터(Sharded Cluster)

02장: 스토리지 엔진
2.1 플러그인 스토리지 엔진
- 2.1.1 MongoDB 스토리지 엔진
- 2.1.2 스토리지 엔진 혼합 사용
2.2 MMAPv1 스토리지 엔진
- 2.2.1 MMAPv1 스토리지 엔진 설정
- 2.2.2 데이터 파일 구조
- 2.2.3 MongoDB 서버 상태 확인
- 2.2.4 운영체제 캐시
- 2.2.5 데이터 파일 프레그멘테이션
2.3 WiredTiger 스토리지 엔진
- 2.3.1 WiredTiger 스토리지 엔진 설정
- 2.3.2 WiredTiger 스토리지의 저장 방식
- 2.3.3 데이터 파일 구조
- 2.3.4 WiredTiger의 내부 작동 방식
- 2.3.5 공유 캐시
- 2.3.6 캐시 이빅션(Cache Eviction)
- 2.3.7 체크포인트(Checkpoint)
- 2.3.8 MVCC(Multi Version Concurrency Control)
- 2.3.9 데이터 블록(페이지)
- 2.3.10 운영체제 캐시(페이지 캐시)
- 2.3.11 압축
- 2.3.12 암호화
2.4 메모리 스토리지 엔진
- 2.4.1 Percona MongoDB의 메모리 스토리지 엔진 설정
- 2.4.2 Percona 메모리 스토리지 엔진의 특성
2.5 기타 스토리지 엔진

03장: 복제
3.1 복제란?
- 3.1.1 컨센서스 알고리즘(Consensus Algorithm)
- 3.1.2 복제의 목적
3.2 레플리카 셋 멤버
- 3.2.1 프라이머리(Primary)
- 3.2.2 세컨드리(Secondary)
- 3.2.3 아비터(Arbiter)
3.3 프라이머리 선출(Primary Election)
- 3.3.1 프라이머리 텀(Primary Term)
- 3.3.2 프라이머리 스텝 다운(Primary Step Down)
- 3.3.3 프라이머리 선출 시나리오
- 3.3.4 프라이머리 선출 시 정족수(Quorum)의 의미
- 3.3.5 롤백(Rollback)
- 3.3.6 롤백(Rollback) 데이터 재처리
3.4 복제 아키텍처
- 3.4.1 복제 로그(OpLog) 구조
- 3.4.2 local 데이터베이스
- 3.4.3 초기 동기화(Initial Sync)
- 3.4.4 실시간 복제(Replication)
3.5 복제 로그(Operation Log) 설정
- 3.5.1 OpLog 컬렉션 크기 설정
- 3.5.2 복제 동기화 상태 확인
- 3.5.3 OpLog 컬렉션과 백업
3.6 레플리카 셋 설정
- 3.6.1 하트비트(Heartbeat) 메시지 주기와 프라이머리 선출 타임아웃
- 3.6.2 레플리카 셋 멤버 설정
3.7 레플리카 셋 배포
- 3.7.1 레플리카 셋 멤버의 수
- 3.7.2 DR(Disaster Recovery) 구성
- 3.7.3 레플리카 셋 배포 시 주의 사항

04장: 샤딩
4.1 샤딩(Sharding)이란?
- 4.1.1 샤딩의 필요성
- 4.1.2 샤딩의 종류
4.2 MongoDB 샤딩 아키텍처
- 4.2.1 샤드 클러스터(Sharded Cluster) 컴포넌트
- 4.2.2 샤드 클러스터의 쿼리 수행 절차(라우터와 컨피그 서버의 통신)
- 4.2.3 컨피그 서버
- 4.2.4 컨피그 서버의 복제 방식
- 4.2.5 컨피그 서버 가용성과 쿼리 실행
- 4.2.6 라우터(mongos)
- 4.2.7 라우터의 쿼리 분산
- 4.2.8 라우터 배포
- 4.2.9 컨넥션 풀 관리
- 4.2.10 백업 복구 시 주의 사항
4.3 샤딩 알고리즘
- 4.3.1 청크(Chunk)
- 4.3.2 레인지 샤딩(Range Sharding)
- 4.3.3 해시 샤딩(Hashed Sharding)
- 4.3.4 지역 기반 샤딩(Zone Sharding)
- 4.3.5 샤드 키
4.4 프라이머리 샤드
4.5 청크 밸런싱
- 4.5.1 샤드 클러스터 밸런서
- 4.5.2 청크 스플릿(Chunk split)
- 4.5.3 청크 머지(Chunk merge)
- 4.5.4 청크 이동(Chunk migration)
- 4.5.5 청크 사이즈 변경
- 4.5.6 점보 청크(Jumbo Chunk)
- 4.5.7 고아 도큐먼트(Orphaned document) 삭제
4.6 샤딩으로 인한 제약
- 4.6.1 트랜잭션
- 4.6.2 샤딩과 유니크 인덱스
- 4.6.3 조인과 그래프 쿼리
- 4.6.4 기존 컬렉션에 샤딩 적용

05장: 인덱스
5.1 디스크 읽기 방식
- 5.1.1 디스크 저장 매체
- 5.1.2 랜덤 I/O와 순차 I/O
5.2 인덱스란?
5.3 MongoDB 인덱스의 개요
- 5.3.1 클러스터링 인덱스
- 5.3.2 인덱스 내부
- 5.3.3 로컬 인덱스(Local Index)
- 5.3.4 인덱스 키 엔트리 자료 구조
5.4 B-Tree 인덱스
- 5.4.1 구조 및 특성
- 5.4.2 B-Tree 인덱스 키 추가 및 삭제
- 5.4.3 B-Tree 인덱스 사용에 영향을 미치는 요소
- 5.4.4 B-Tree 인덱스를 통한 데이터 읽기
- 5.4.5 컴파운드 인덱스(Compound Index)
- 5.4.6 B-Tree 인덱스의 정렬 및 스캔 방향
- 5.4.7 B-Tree 인덱스의 가용성과 효율성
5.5 해시(Hash) 인덱스
- 5.5.1 해시 인덱스의 구조 및 특성
- 5.5.2 해시 인덱스의 가용성 및 효율성
- 5.5.3 MongoDB 해시 인덱스의 구조 및 특성
- 5.5.4 MongoDB 해시 인덱스의 제한 사항
5.6 멀티 키 인덱스
- 5.6.1 멀티 키 인덱스의 주의 사항
- 5.6.2 멀티 키 인덱스의 성능
- 5.6.3 멀티 키 인덱스의 제한 사항
5.7 전문 검색 인덱스
- 5.7.1 형태소 분석 알고리즘
- 5.7.2 N-Gram 알고리즘
- 5.7.3 형태소 분석과 N-Gram의 장단점
- 5.7.4 전문 검색 인덱스의 활용
- 5.7.5 부정 비교와 문장 검색
- 5.7.6 MongoDB 전문 검색 인덱스의 버전 호환성
- 5.7.7 전문 검색 인덱스의 제약 사항
5.8 공간 검색 인덱스
- 5.8.1 GeoHash 알고리즘
- 5.8.2 S2 Geometry 알고리즘
- 5.8.3 MongoDB의 공간 인덱스
- 5.8.4 MongoDB의 컴파운드 공간 인덱스
5.9 인덱스 속성
- 5.9.1 프라이머리 키와 세컨드리 인덱스
- 5.9.2 유니크 인덱스
- 5.9.3 Partial 인덱스와 Sparse 인덱스
- 5.9.4 TTL 인덱스
- 5.9.5 인덱스 콜레이션(대소문자 구분 설정)
- 5.9.6 외래 키

06장: 잠금과 트랜잭션
6.1 잠금
- 6.1.1 MongoDB 엔진의 잠금
- 6.1.2 WiredTiger 스토리지 엔진의 잠금
- 6.1.3 잠금 Yield
- 6.1.4 잠금 진단
6.2 트랜잭션
- 6.2.1 쓰기 충돌(Write Conflict)
- 6.2.2 단일 도큐먼트 트랜잭션(Single Document transaction)
- 6.2.3 문장의 트랜잭션(Statement transaction) 처리
6.3 격리 수준
- 6.3.1 READ-COMMITTED
- 6.3.2 SNAPSHOT(REPEATABLE-READ)
- 6.3.3 MongoDB 서버의 격리 수준
- 6.3.4 MongoDB 서버의 격리 수준과 정렬
6.4 Read & Write Concern과 Read Preference
- 6.4.1 Write Concern
- 6.4.2 Read Concern
- 6.4.3 Read Preference
- 6.4.4 maxStalenessSeconds 설정
- 6.4.5 샤딩 환경의 중복 도큐먼트 처리

07장: 데이터 모델링
7.1 데이터베이스와 컬렉션
- 7.1.1 네임스페이스
- 7.1.2 데이터베이스
- 7.1.3 컬렉션
- 7.1.4 뷰(View)
- 7.1.5 BSON 도큐먼트
- 7.1.6 제한 사항
7.2 데이터 타입
- 7.2.1 데이터 타입 비교
- 7.2.2 필드 값의 비교 및 정렬
- 7.2.3 문자셋과 콜레이션
- 7.2.4 MongoDB 확장 JSON(Extended JSON)
7.3 모델링 고려 사항
- 7.3.1 도큐먼트의 크기
- 7.3.2 정규화와 역정규화(Document Referencing vs. Embedding)
- 7.3.3 서브 도큐먼트(Sub Document)
- 7.3.4 배열(Array)
- 7.3.5 필드 이름
- 7.3.6 프레그멘테이션(Fragmentation)과 패딩(Padding)
- 7.3.7 도큐먼트 유효성 체크
- 7.3.8 조인

08장: 쿼리 개발과 튜닝
8.1 기본 CRUD 쿼리
- 8.1.1 쿼리 작성
8.2 확장 검색 쿼리
- 8.2.1 맵리듀스(Map Reduce)
- 8.2.2 Aggregation
- 8.2.3 Fulltext Search
- 8.2.4 공간 검색
8.3 스키마 변경(DDL)
- 8.3.1 데이터베이스 관리
- 8.3.2 컬렉션 관리
- 8.3.3 인덱스 관리

09장: 실행 계획 및 쿼리 최적화
9.1 실행 계획
- 9.1.1 쿼리의 처리 과정
- 9.1.2 실행 계획 수립
- 9.1.3 옵티마이저 옵션
- 9.1.4 플랜 캐시
- 9.1.5 실행 계획 스테이지
- 9.1.6 쿼리 실행 계획 해석
9.2 쿼리 최적화
- 9.2.1 실행 계획의 쿼리 튜닝 포인트
- 9.2.2 슬로우 쿼리 로그 분석 및 튜닝
- 9.2.3 쿼리 프로파일링
- 9.2.4 인덱스 힌트

10장: 보안
10.1 인증(Authentication)
- 10.1.1 내부 인증
- 10.1.2 사용자 인증
10.2 권한(Authorization)
- 10.2.1 액션(Action)
- 10.2.2 내장(Built-in)된 역할(Role)
- 10.2.3 사용자 정의 역할(Role)
10.3 암호화(Encryption)
- 10.3.1 데이터 암호화 방식
- 10.3.2 MongoDB TDE 구현

부록: 백업 및 복구
A.1 mongodump와 mongorestore를 이용한 논리 백업 및 복구
- A.1.1 백업
- A.1.2 복구
A.2 물리 백업 및 복구
- A.2.1 셧다운 상태의 백업
- A.2.2 복제 중지 상태의 백업
- A.2.3 파일시스템 스냅샷 백업
- A.2.4 Percona 온라인 백업
- A.2.5 물리 백업 복구
A.3 PIT(Point-In-Time) 복구

관련이미지

저자소개

생년월일 -
출생지 -
출간도서 0종
판매수 0권

컴퓨터 과학을 전공하고, 금융권의 CRM/DW 프로젝트 리더로 참여했으며, 2년여간 DW를 위한 ETL 솔루션을 개발했다. 이후 네이버와 라인의 DBA로 근무했으며 현재 카카오에서 DB 운영과 트러블슈팅 그리고 신기술 벤치마킹과 DBMS 엔진 최적화를 수행하고 있다. 또한 지금까지 배운 내용과 경험한 것을 전파하기 위해서 저술 활동과 세미나를 진행하고 있다.

[저서]
- PHP 5 웹 프로그래밍 (2007. 대림)
- Real MySQL(2012. 위키북스)
- Real MariaDB(2014. 위키북스)

[번역서]
- MySQL 성능 최적화(2010. 위키북스)

이 상품의 시리즈

(총 20권 / 현재구매 가능도서 16권)

펼쳐보기

컴퓨터/인터넷 분야에서 많은 회원이 구매한 책

    리뷰

    0.0 (총 0건)

    구매 후 리뷰 작성 시, 북피니언 지수 최대 600점

    리뷰쓰기

    기대평

    작성시 유의사항

    평점
    0/200자
    등록하기

    기대평

    10.0

    교환/환불

    교환/환불 방법

    ‘마이페이지 > 취소/반품/교환/환불’ 에서 신청함, 1:1 문의 게시판 또는 고객센터(1577-2555) 이용 가능

    교환/환불 가능 기간

    고객변심은 출고완료 다음날부터 14일 까지만 교환/환불이 가능함

    교환/환불 비용

    고객변심 또는 구매착오의 경우에만 2,500원 택배비를 고객님이 부담함

    교환/환불 불가사유

    반품접수 없이 반송하거나, 우편으로 보낼 경우 상품 확인이 어려워 환불이 불가할 수 있음
    배송된 상품의 분실, 상품포장이 훼손된 경우, 비닐랩핑된 상품의 비닐 개봉시 교환/반품이 불가능함

    소비자 피해보상

    소비자 피해보상의 분쟁처리 등에 관한 사항은 소비자분쟁해결기준(공정거래위원회 고시)에 따라 비해 보상 받을 수 있음
    교환/반품/보증조건 및 품질보증 기준은 소비자기본법에 따른 소비자 분쟁 해결 기준에 따라 피해를 보상 받을 수 있음

    기타

    도매상 및 제작사 사정에 따라 품절/절판 등의 사유로 주문이 취소될 수 있음(이 경우 인터파크도서에서 고객님께 별도로 연락하여 고지함)

    배송안내

    • 인터파크 도서 상품은 택배로 배송되며, 출고완료 1~2일내 상품을 받아 보실 수 있습니다

    • 출고가능 시간이 서로 다른 상품을 함께 주문할 경우 출고가능 시간이 가장 긴 상품을 기준으로 배송됩니다.

    • 군부대, 교도소 등 특정기관은 우체국 택배만 배송가능하여, 인터파크 외 타업체 배송상품인 경우 발송되지 않을 수 있습니다.

    • 배송비

    도서(중고도서 포함) 구매

    2,000원 (1만원이상 구매 시 무료배송)

    음반/DVD/잡지/만화 구매

    2,000원 (2만원이상 구매 시 무료배송)

    도서와 음반/DVD/잡지/만화/
    중고직배송상품을 함께 구매

    2,000원 (1만원이상 구매 시 무료배송)

    업체직접배송상품 구매

    업체별 상이한 배송비 적용