Redis设计与实现 作者:黄健宏出版时间:2014内容简介 《Redis设计与实现》对Redis的大多数单机功能以及所有多机功能的实现原理进行了介绍,展示了这些功能的核心数据结构以及关键的算法思想。通过阅读本书,读者可以快速、有效地了解Redis的内部构造以及运作机制,这些知识可以帮助读者更好、更高效地使用Redis。本书主要分为四大部分。第一部分“数据结构与对象”介绍了Redis中的各种对象及其数据结构,并说明这些数据结构如何影响对象的功能和性能。第二部分“单机数据库的实现”对Redis实现单机数据库的方法进行了介绍,包括数据库、RDB持久化、AOF持久化、事件等。第三部分“多机数据库的实现”对Redis的Sentinel、复制(replication)、集群(cluster)三个多机功能进行了介绍。第四部分“独立功能的实现”对Redis中各个相对独立的功能模块进行了介绍,涉及发布与订阅、事务、Lua脚本、排序、二进制位数组、慢查询日志、监视器等。目录前言致谢第1章 引言 11.1 Redis版本说明 11.2 章节编排 11.3 推荐的阅读方法 41.4 行文规则 41.5 配套网站 5 第一部分·数据结构与对象第2章 简单动态字符串 82.1 SDS的定义 92.2 SDS与C字符串的区别 102.3 SDS API 172.4 重点回顾 182.5 参考资料 18第3章 链表 193.1 链表和链表节点的实现 203.2 链表和链表节点的API 213.3 重点回顾 22第4章 字典 234.1 字典的实现 244.2 哈希算法 274.3 解决键冲突 284.4 rehash 294.5 渐进式rehash 324.6 字典API 364.7 重点回顾 37第5章 跳跃表 385.1 跳跃表的实现 395.2 跳跃表API 445.3 重点回顾 45第6章 整数集合 466.1 整数集合的实现 466.2 升级 486.3 升级的好处 506.4 降级 516.5 整数集合API 516.6 重点回顾 51第7章 压缩列表 527.1 压缩列表的构成 527.2 压缩列表节点的构成 547.3 连锁更新 577.4 压缩列表API 597.5 重点回顾 59第8章 对象 608.1 对象的类型与编码 608.2 字符串对象 648.3 列表对象 688.4 哈希对象 718.5 集合对象 758.6 有序集合对象 778.7 类型检查与命令多态 818.8 内存回收 848.9 对象共享 858.10 对象的空转时长 878.11 重点回顾 88 第二部分·单机数据库的实现第9章 数据库 909.1 服务器中的数据库 909.2 切换数据库 919.3 数据库键空间 939.4 设置键的生存时间或过期时间 999.5 过期键删除策略 1079.6 Redis的过期键删除策略 1089.7 AOF、RDB和复制功能对过期键的处理 1119.8 数据库通知 1139.9 重点回顾 117第10章 RDB持久化 11810.1 RDB 文件的创建与载入 11910.2 自动间隔性保存 12110.3 RDB 文件结构 12510.4 分析RDB文件 13310.5 重点回顾 13710.6 参考资料 137第11章 AOF持久化 13811.1 AOF持久化的实现 13911.2 AOF文件的载入与数据还原 14211.3 AOF重写 14311.4 重点回顾 150第12章 事件 15112.1 文件事件 15112.2 时间事件 15612.3 事件的调度与执行 15912.4 重点回顾 16112.5 参考资料 161第13章 客户端 16213.1 客户端属性 16313.2 客户端的创建与关闭 17213.3 重点回顾 174第14章 服务器 17614.1 命令请求的执行过程 17614.2 serverCron函数 18414.3 初始化服务器 19214.4 重点回顾 196 第三部分·多机数据库的实现第15章 复制 19815.1 旧版复制功能的实现 19915.2 旧版复制功能的缺陷 20115.3 新版复制功能的实现 20315.4 部分重同步的实现 20415.5 PSYNC 命令的实现 20915.6 复制的实现 21115.7 心跳检测 21615.8 重点回顾 218第16章 Sentinel 21916.1 启动并初始化Sentinel 22016.2 获取主服务器信息 22716.3 获取从服务器信息 22916.4 向主服务器和从服务器发送信息 23016.5 接收来自主服务器和从服务器的频道信息 23116.6 检测主观下线状态 23416.7 检查客观下线状态 23616.8 选举领头Sentinel 23816.9 故障转移 24016.10 重点回顾 24316.11 参考资料 244第17章 集群 24517.1 节点 24517.2 槽指派 25117.3 在集群中执行命令 25817.4 重新分片 26517.5 ASK错误 26717.6 复制与故障转移 27317.7 消息 28117.8 重点回顾 288 第四部分·独立功能的实现第18章 发布与订阅 29018.1 频道的订阅与退订 29218.2 模式的订阅与退订 29518.3 发送消息 29818.4 查看订阅信息 30018.5 重点回顾 30318.6 参考资料 304第19章 事务 30519.1 事务的实现 30619.2 WATCH 命令的实现 31019.3 事务的ACID 性质 31419.4 重点回顾 31919.5 参考资料 320第20章 Lua脚本 32120.1 创建并修改Lua 环境 32220.2 Lua 环境协作组件 32720.3 EVAL命令的实现 32920.4 EVALSHA 命令的实现 33220.5 脚本管理命令的实现 33320.6 脚本复制 33620.7 重点回顾 34220.8 参考资料 343第21章 排序 34421.1 SORT 命令的实现 34521.2 ALPHA 选项的实现 34721.3 ASC 选项和DESC 选项的实现 34821.4 BY选项的实现 35021.5 带有ALPHA 选项的BY 选项的实现 35221.6 LIMIT 选项的实现 35321.7 GET选项的实现 35521.8 STORE 选项的实现 35821.9 多个选项的执行顺序 35921.10 重点回顾 361第22章 二进制位数组 36222.1 位数组的表示 36322.2 GETBIT命令的实现 36522.3 SETBIT 命令的实现 36622.4 BITCOUNT 命令的实现 36922.5 BITOP 命令的实现 37622.6 重点回顾 37722.7 参考资料 377第23章 慢查询日志 37823.1 慢查询记录的保存 38023.2 慢查询日志的阅览和删除 38223.3 添加新日志 38323.4 重点回顾 385第24章 监视器 38624.1 成为监视器 38724.2 向监视器发送命令信息 38724.3 重点回顾 388 上一篇: 经典原版书库 Java语言规范 第三版 英文版 下一篇: JAVA并发编程实践