发表于2024-11-23
书名: | Redis设计与实现|3770218 |
图书定价: | 79元 |
图书作者: | 黄健宏 |
出版社: | 机械工业出版社 |
出版日期: | 2014/6/1 0:00:00 |
ISBN号: | 9787111464747 |
开本: | 16开 |
页数: | 388 |
版次: | 1-1 |
内容简介 |
《Redis设计与实现》全面而完整地讲解了Redis的内部机制与实现方式,对Redis的大多数单机功能以及所有多机功能的实现原理进行了介绍,展示了这些功能的核心数据结构以及关键的算法思想,图示丰富,描述清晰,并给出大量参考信息。通过阅读本书,读者可以快速、有效地了解Redis的内部构造以及运作机制,更好、更高效地使用Redis。 《Redis设计与实现》主要分为四大部分。第一部分“数据结构与对象”介绍了Redis中的各种对象及其数据结构,并说明这些数据结构如何影响对象的功能和性能。第二部分“单机数据库的实现”对Redis实现单机数据库的方法进行了介绍,包括数据库、RDB持久化、AOF持久化、事件等。第三部分“多机数据库的实现”对Redis的Sentinel、复制、集群三个多机功能进行了介绍。第四部分“独立功能的实现”对Redis中各个相对独立的功能模块进行了介绍,涉及发布与订阅、事务、Lua脚本、排序、二进制位数组、慢查询日志、监视器等。本书作者专门维护了www.redisbook.com网站,提供带有详细注释的Redis源代码,以及本书相关的更新内容。 |
目录 |
《Redis设计与实现》 前言 致谢 第1章 引言1 1.1 Redis版本说明1 1.2 章节编排1 1.3 推荐的阅读方法4 1.4 行文规则4 1.5 配套网站5 第一部分 数据结构与对象 第2章 简单动态字符串8 2.1 SDS的定义9 2.2 SDS与C字符串的区别10 2.3 SDS API17 2.4 重点回顾18 2.5 参考资料18 第3章 链表19 3.1 链表和链表节点的实现20 3.2 链表和链表节点的API21 3.3 重点回顾22 第4章 字典23 4.1 字典的实现24 4.2 哈希算法27 4.3 解决键冲突28 4.4 rehash 29 4.5 渐进式rehash32 4.6 字典API36 4.7 重点回顾37 第5章 跳跃表38 5.1 跳跃表的实现39 5.2 跳跃表API44 5.3 重点回顾45 第6章 整数集合46 6.1 整数集合的实现46 6.2 升级48 6.3 升级的好处50 6.4 降级51 6.5 整数集合API51 6.6 重点回顾51 第7章 压缩列表52 7.1 压缩列表的构成52 7.2 压缩列表节点的构成54 7.3 连锁更新57 7.4 压缩列表API59 7.5 重点回顾59 第8章 对象60 8.1 对象的类型与编码60 8.2 字符串对象64 8.3 列表对象68 8.4 哈希对象71 8.5 集合对象75 8.6 有序集合对象77 8.7 类型检查与命令多态81 8.8 内存回收84 8.9 对象共享85 8.10 对象的空转时长87 8.11 重点回顾88 第二部分 单机数据库的实现 第9章 数据库90 9.1 服务器中的数据库90 9.2 切换数据库91 9.3 数据库键空间93 9.4 设置键的生存时间或过期时间99 9.5 过期键删除策略107 9.6 Redis的过期键删除策略108 9.7 AOF、RDB和复制功能对过期键的处理111 9.8 数据库通知113 9.9 重点回顾117 第10章 RDB持久化118 10.1 RDB 文件的创建与载入119 10.2 自动间隔性保存121 10.3 RDB 文件结构125 10.4 分析RDB文件133 10.5 重点回顾137 10.6 参考资料137 第11章 AOF持久化138 11.1 AOF持久化的实现139 11.2 AOF文件的载入与数据还原142 11.3 AOF重写143 11.4 重点回顾150 第12章 事件151 12.1 文件事件151 12.2 时间事件156 12.3 事件的调度与执行159 12.4 重点回顾161 12.5 参考资料161 第13章 客户端162 13.1 客户端属性163 13.2 客户端的创建与关闭172 13.3 重点回顾174 第14章 服务器176 14.1 命令请求的执行过程176 14.2 serverCron函数184 14.3 初始化服务器192 14.4 重点回顾196 第三部分 多机数据库的实现 第15章 复制198 15.1 旧版复制功能的实现199 15.2 旧版复制功能的缺陷201 15.3 新版复制功能的实现203 15.4 部分重同步的实现204 15.5 PSYNC 命令的实现209 15.6 复制的实现211 15.7 心跳检测216 15.8 重点回顾218 第16章 Sentinel219 16.1 启动并初始化Sentinel 220 16.2 获取主服务器信息227 16.3 获取从服务器信息229 16.4 向主服务器和从服务器发送信息230 16.5 接收来自主服务器和从服务器的频道信息231 16.6 检测主观下线状态234 16.7 检查客观下线状态236 16.8 选举领头Sentinel 238 16.9 故障转移240 16.10 重点回顾243 16.11 参考资料244 第17章 集群245 17.1 节点245 17.2 槽指派251 17.3 在集群中执行命令258 17.4 重新分片265 17.5 ASK错误267 17.6 复制与故障转移273 17.7 消息281 17.8 重点回顾288 第四部分 独立功能的实现 第18章 发布与订阅290 18.1 频道的订阅与退订292 18.2 模式的订阅与退订295 18.3 发送消息298 18.4 查看订阅信息300 18.5 重点回顾303 18.6 参考资料304 第19章 事务305 19.1 事务的实现306 19.2 WATCH 命令的实现310 19.3 事务的ACID 性质314 19.4 重点回顾319 19.5 参考资料320 第20章 Lua脚本321 20.1 创建并修改Lua 环境322 20.2 Lua 环境协作组件327 20.3 EVAL命令的实现329 20.4 EVALSHA 命令的实现332 20.5 脚本管理命令的实现333 20.6 脚本复制336 20.7 重点回顾342 20.8 参考资料343 第21章 排序344 21.1 SORT 21.2 ALPHA 选项的实现347 21.3 ASC 选项和DESC 选项的实现348 21.4 BY选项的实现350 21.5 带有ALPHA 选项的BY 选项的实现352 21.6 LIMIT 选项的实现353 21.7 GET选项的实现355 21.8 STORE 选项的实现358 21.9 多个选项的执行顺序359 21.10 重点回顾361 第22章 二进制位数组362 22.1 位数组的表示363 22.2 GETBIT命令的实现365 22.3 SETBIT 命令的实现366 22.4 BITCOUNT 命令的实现369 22.5 BITOP 命令的实现376 22.6 重点回顾377 22.7 参考资料377 第23章 慢查询日志378 23.1 慢查询记录的保存380 23.2 慢查询日志的阅览和删除382 23.3 添加新日志383 23.4 重点回顾385 第24章 监视器386 24.1 成为监视器387 24.2 向监视器发送命令信息387 24.3 重点回顾388 |
Redis设计与实现 计算机与互联网 书籍|3770218 下载 mobi pdf epub txt 电子书 格式 2024
Redis设计与实现 计算机与互联网 书籍|3770218 下载 mobi epub pdf 电子书Redis设计与实现 计算机与互联网 书籍|3770218 mobi epub pdf txt 电子书 格式下载 2024