内容简介:
MongoDB是为处理大数据而生的一款面向文档的数据库,由10gen公司开发和维护。本书作者Kyle Banker曾在该公司负责MongoDB驱动程序的维护,对各方面技术细节都了如指掌,本书也是在大量第一手资料的基础上形成的,其权威性毋庸置疑。
本书基于MongoDB 2.0+,全面系统地讲解了设计、实现、安装和维护MongoDB的各方面内容。全书分三部分,第一部分从基于文档的数据与传统关系型数据库的差别讲起,介绍了MongoDB的基本概念及安装使用。第二部分是一个实战式教程,结合示例讲解了MongoDB的CRUD操作,以及实现系统安全、灵活和高效的设计原则及模式。第三部分侧重数据库的维护和管理,深入到MongoDB背后的技术细节,给出了对管理员和开发者都极有价值的建议。
本书篇幅适中,内容深浅得当,文字通俗易懂,再配以直观形象的插图和贴近实战的代码示例,非常适合MongoDB学习者、开发人员及管理员学习参考。
本书内容:
MongoDB介绍及其优劣势
MongoDB的Shell界面
使用MongoDB的简单应用
如何通过以文档为中心的方式看待数据
编写查询,以MapReduce方式聚合数据
更新和删除数据及相关性能考量
寻找和改进慢查询
MongoDB的复制与分片
MongoDB的监控、备份及恢复
目 录
第一部分 入门指南
第1章 为现代Web而生的数据库2
1.1 生于云端3
1.2 MongoDB的主要特性4
1.2.1 文档数据模型4
1.2.2 即时查询6
1.2.3 二级索引7
1.2.4 复制8
1.2.5 速度和持久性9
1.2.6 数据库扩展10
1.3 MongoDB的核心服务器和工具11
1.3.1 核心服务器11
1.3.2 JavaScript Shell12
1.3.3 数据库驱动12
1.3.4 命令行工具13
1.4 为什么选择MongoDB13
1.4.1 MongoDB与其他数据库的对比14
1.4.2 使用场景和生产部署16
1.5 提示与局限18
1.6 小结18
第2章 MongoDB JavaScript Shell19
2.1 深入MongoDB Shell19
2.1.1 启动Shell20
2.1.2 插入与查询20
2.1.3 更新文档22
2.1.4 删除数据23
2.2 创建索引并查询24
2.2.1 创建一个大集合24
2.2.2 索引与explain()25
2.3 基本管理27
2.3.1 获取数据库信息27
2.3.2 命令工作原理29
2.4 获得帮助30
2.5 小结31
第3章 使用MongoDB编写程序32
3.1 通过Ruby使用MongoDB32
3.1.1 安装与连接33
3.1.2 用Ruby插入文档34
3.1.3 查询与游标34
3.1.4 更新与删除35
3.1.5 数据库命令36
3.2 驱动是如何工作的37
3.2.1 对象ID生成37
3.2.2 BSON38
3.2.3 网络传输40
3.3 构建简单的应用程序41
3.3.1 配置41
3.3.2 收集数据42
3.3.3 查看归档43
3.4 小结46
第二部分 MongoDB与应用程序开发
第4章 面向文档的数据48
4.1 Schema设计原则48
4.2 设计电子商务数据模型49
4.2.1 产品与分类50
4.2.2 用户与订单53
4.2.3 评论55
4.3 具体细节:数据库、集合与文档56
4.3.1 数据库56
4.3.2 集合58
4.3.3 文档与插入61
4.4 小结65
第5章 查询与聚合66
5.1 电子商务查询66
5.1.1 产品、分类与评论66
5.1.2 用户与订单68
5.2 MongoDB查询语言70
5.2.1 查询选择器70
5.2.2 查询选项78
5.3 聚合指令79
5.3.1 根据用户对评论进行分组79
5.3.2 根据地域对订单应用MapReduce81
5.4 详解聚合82
5.4.1 max()与min()82
5.4.2 distinct83
5.4.3 group83
5.4.4 map-reduce84
5.5 小结86
第6章 更新、原子操作与删除87
6.1 文档更新入门87
6.2 电子商务数据模型中的更新89
6.2.1 产品与分类90
6.2.2 评论93
6.2.3 订单94
6.3 原子文档处理96
6.3.1 订单状态变迁97
6.3.2 库存管理98
6.4 具体细节:MongoDB的更新与删除101
6.4.1 更新类型与选项101
6.4.2 更新操作符103
6.4.3 findAndModify命令106
6.4.4 删除106
6.4.5 并发性、原子性与隔离性107
6.4.6 更新性能说明107
6.5 小结109
第三部分 精通MongoDB
第7章 索引与查询优化112
7.1 索引理论112
7.1.1 思想实验112
7.1.2 核心索引概念115
7.1.3 B树118
7.2 索引实践119
7.2.1 索引类型119
7.2.2 索引管理121
7.3 查询优化125
7.3.1 识别慢查询125
7.3.2 分析慢查询127
7.3.3 查询模式133
7.4 小结134
第8章 复制135
8.1 复制概述135
8.1.1 为什么复制很重要135
8.1.2 复制的使用场景136
8.2 副本集137
8.2.1 配置137
8.2.2 复制的工作原理141
8.2.3 管理146
8.3 主从复制152
8.4 驱动与复制152
8.4.1 连接与故障转移153
8.4.2 写关注154
8.4.3 读扩展155
8.4.4 标签156
8.5 小结158
第9章 分片159
9.1 分片概述159
9.1.1 何谓分片160
9.1.2 分片的工作原理161
9.2 示例分片集群164
9.2.1 配置164
9.2.2 写入分片集群168
9.3 分片集群的查询与索引173
9.3.1 分片查询类型173
9.3.2 索引177
9.4 选择分片键178
9.4.1 低效的分片键178
9.4.2 理想的分片键179
9.5 生产环境中的分片180
9.5.1 部署与配置180
9.5.2 管理184
9.6 小结188
第10章 部署与管理189
10.1 部署189
10.1.1 部署环境189
10.1.2 服务器配置193
10.1.3 数据的导入与导出194
10.1.4 安全195
10.2 监控与诊断197
10.2.1 日志197
10.2.2 监控工具198
10.2.3 外部监控应用程序201
10.2.4 诊断工具(mongosniff、bsondump)201
10.3 维护202
10.3.1 备份与恢复202
10.3.2 压紧与修复204
10.3.3 升级205
10.4 性能调优205
10.4.1 为提升性能检查索引和查询206
10.4.2 添加内存206
10.4.3 提升磁盘性能207
10.4.4 水平扩展207
10.4.5 寻求专业帮助207
10.5 小结208
附录A 安装209
附录B 设计模式216
附录C 二进制数据与GridFS226
附录D 在PHP、Java与C++中使用MongoDB232
附录E 空间索引240
《能源互联网发展研究》内容简介:本书全面介绍了国内能源互联网的发展现状及进展,共分四篇,第1篇为战略篇,第2篇为技术篇,第3篇
《电子工程师必备:关键技能速成宝典》内容简介:本书以培养实际动手操作技能为出发点,从基础知识讲起,系统地介绍了电子工程师必
《Wireshark数据包分析实战(第2版)》从网络嗅探与数据包分析的基础知识开始,渐进地介绍Wireshark的基本使用方法及其数据包分析功
虚拟现实技术 本书特色 陈怀友、张天驰、张菁编著的《虚拟现实技术(中文版计算机科学与技术学科研究生系列教材)》对虚拟现实技术及应用进行详细的探讨,运用多个典型的...
主板维修技能实训(芯片级) 内容简介 本书结合大量图解与实例,循序渐进地讲解了主板的结构和电路组成,常用维修工具,元器件好坏的判定方法,总线插槽和测试点,以及接...
《周有光传》内容简介:《汉语拼音之父:周有光传》主要内容简介::半个世纪前,他从经济学教授变身语言文字学家。花三年时间倾力打磨
《Tableau数据可视化》内容简介:本书由专业的数据分析师基于Tableau 10.1精心编撰,详细介绍Tableau的数据连接、图形编辑与展示功
支持向量机鲁棒性模型与算法研究 本书特色 支持向量机是基于统计学习理论,以结构风险*小化为原则的一种针对小样本情况的新型机器学习方法,具有结构简单、全局*解和泛...
《趣学JavaScript》内容简介:本书用轻松愉快的方式,通过耐心的、按部就班的示例,以及充满乐趣的图示,帮助读者轻松地学习编程基
《算法之美——隐匿在数据结构背后的原理(C++版)》围绕算法与数据结构这个话题,循序渐进、深入浅出地介绍了现代计算机技术中常
数据库系统原理及应用 本书特色 本书特色:根据数据库发展的过程与特点,从不同角度出发,凝炼出数据库发展的三条线索覆盖的知识面广,既包括数据库理论,又包括数据库应...
《SAS技术内幕》内容简介:本书共27章,分为上下两卷:上卷介绍SAS编程基础与使用方法,是广大程序员快速掌握SAS编程技术的简明开发
CADCAMCAE工程应用丛书ANSYS Fluent流体计算从入门到精通(2020版) 本书特色 适读人群 :适合广大Fluent初、中级读者学习使用;也可作...
肓信号处理是现代数学信号处理、计算智能学近年来迅速发展的重要方向。在电子信息、通信、生物医学、图像增强、雷达、地球物理信
《西方近现代建筑史》内容简介:本书透过中国建筑史学家的视角,对19世纪及20世纪西方建筑的演变历程作了系统的描述与阐释,并对百
《历史文化名城名镇名村系列:东村》内容简介:东村,古称“东园村”,这个太湖边尚存的为数不多的千年古村,历史遗存丰富,现存明
《LabVIEW大学实用教程(第3版)》主要内容:LabVIEW是一种图形化编程语言,广泛用于仿真、数据采集、仪器控制、测量分析和数据显示
《中国哲学创新方法论研究》内容简介:中国哲学学科自20世纪初依西方哲学范式建成以来,始终面临着方法论的困境,无论是在概念创造
精通UG NX5中文版-基础入门篇(附赠1CD.含4小时语音视频教学) 内容简介 全书共分14章,主要介绍了ug nx5的绘图命令、实体特征以及各项命令的操作与...
TheCLOSmetaobjectprotocolisanelegant,high-performanceextensiontotheCommonLispObj...