转载至: https://www.jb51.net/books/115168.html
下载链接: 点我一键跳转到 下载链接
下载声明: 本资料仅供个人学习和研究使用,不能用于商业用途,请在下载后24小时内删除。如果喜欢,请购买正版!
内容简介:
在云计算时代,传统的关系型数据库的不足凸显出来,尤其是它无法应对大数据量的处理需求。为了弥补这些不足,NoSQL型数据库应运而生,以MongoDB、Hadoop为代表的NoSQL产品以其高性能、强扩展性和高容错性为大家所称道,并在数据库领域掀起了一场新的革命。
本书是一本NoSQL入门书,从最基本的NoSQL发展史开始,介绍了memcached、Tokyo Tyrant、Redis和MongoDB这4种NoSQL数据库的使用背景、优缺点和具体应用实例,并对这4种数据库进行了互相比较,旨在让读者全面了解NoSQL能解决的具体问题,为读者开发数据库提供更多选择。书中最后还介绍了如何将MySQL数据库NoSQL化。
本书适合所有数据库开发人员。
第1章 nosql数据库的基础知识 1
1.1 关系型数据库和nosql数据库 2
1.1.1 什么是nosql 2
1.1.2 关系型数据库简史 2
1.1.3 数据库的分类 3
1.1.4 关系型数据库的优势 5
1.1.5 关系型数据库的不足 5
1.1.6 nosql数据库 9
1.2 nosql数据库是什么 12
1.2.1 键值存储 13
1.2.2 面向文档的数据库 14
1.2.3 面向列的数据库 14
1.3 如何导入nosql数据库 16
1.3.1 始终只是其中一种选择 16
1.3.2 在何种程度上信赖它? 18
第2章 数据库的种类和特征 19
2.1 memcached(临时性键值存储) 20
2.1.1 什么是memcached 20
2.1.2 为什么要使用memcached 20
.2.1.3 特征和用例 21
2.1.4 安装步骤 27
2.1.5 动作确认 29
2.1.6 各种开发语言需要用到的程序库 36
2.1.7 相关工具 37
2.2 tokyo tyrant(永久性键值存储) 44
2.2.1 什么是tokyo tyrant 44
2.2.2 为什么要使用tokyo tyrant 44
2.2.3 特征和用例 44
2.2.4 安装步骤 48
2.2.5 动作确认 50
2.2.6 各种开发语言需要用到的程序库 58
2.2.7 相关工具 58
2.3 redis(临时性/持久性键值存储) 61
2.3.1 什么是redis 61
2.3.2 为什么要使用redis 61
2.3.3 特征和用例 67
2.3.4 安装步骤 71
2.3.5 动作确认 72
2.3.6 各种开发语言需要用到的程序库 81
2.4 mongodb(面向文档的数据库) 82
2.4.1 什么是mongodb 82
2.4.2 为什么要使用mongodb 82
2.4.3 特征和用例 84
2.4.4 安装步骤 87
2.4.5 动作确认 88
2.4.6 各种开发语言需要用到的程序库 100
2.4.7 相关工具 100
第3章 试用nosql数据库 103
3.1 memcached的具体使用实例 104
3.1.1 例① 关系型数据库的缓存 104
3.1.2 例② 音乐视听排行网站 112
3.1.3 例③ 外部api的缓存 119
3.2 tokyo tyrant的具体使用实例 120
3.2.1 例① 在每个页面显示访问量 120
3.3 redis的具体应用实例 130
3.3.1 例① 时间线(time line)形式的web应用 130
3.3.2 例② 查询历史记录 144
3.4 mongodb的具体使用实例 151
3.4.1 例① 问卷调查数据的保存 151
3.4.2 例② 解析数据的存储 165
第4章 性能验证 167
4.1 基本的插入和查询处理的性能 168
4.1.1 假定案例 168
4.1.2 准备工作 171
4.1.3 插入处理的性能 172
4.1.4 查询的性能 172
4.2 不同实例的性能比较 175
4.2.1 tokyo tyrant的addint方法和incr方法 175
4.2.2 对redis的列表类型的数据进行添加和删除 177
4.2.3 mysql的join和mongodb的embed 178
第5章 nosql化的关系型数据库 183
5.1 关于nosql数据库 184
5.1.1 各种nosql数据库的特征 184
5.1.2 运行时的开销以及经验不足的问题 185
5.1.3 将mysql数据库nosql化的方法 185
5.2 尝试使用handlersocket 187
5.2.1 特征 187
5.2.2 为mysql安装handlersocket 188
5.2.3 动作确认 191
5.2.4 handlersocket的性能 197