Day768.大佬推荐的经典的Redis学习资料 -Redis 核心技术与实战

Posted 阿昌喜欢吃黄桃

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Day768.大佬推荐的经典的Redis学习资料 -Redis 核心技术与实战相关的知识,希望对你有一定的参考价值。

大佬推荐的经典的Redis学习资料

Hi,我是阿昌,今天学习记录的是关于经典的Redis学习资料

一、经典书籍

在学习 Redis 时,最常见的需求有三个方面。

  • 日常使用操作:比如常见命令和配置,集群搭建等;
  • 关键技术原理:比如我们介绍过的 IO 模型、AOF 和 RDB 机制等;
  • 在实际使用时的经验教训,比如,Redis 响应变慢了怎么办?Redis 主从库数据不一致怎么办?等等。

1、工具书:《Redis 使用手册》

一本好的工具书,可以帮助快速地了解或查询 Redis 的日常使用命令和操作方法。

《Redis 使用手册》,就是一本非常好用的工具书。

在这本书中,作者把 Redis 的内容分成了三大部分,分别是“数据结构与应用”“附加功能”和“多机功能”。

其中,最有用的就是“数据结构与应用”的内容,因为它提供了丰富的操作命令介绍,不仅涵盖了 Redis 的 5 大基本数据类型的主要操作命令,还介绍了 4 种扩展数据类型的命令操作,包括位图、地址坐标、HyperLogLog 和流。

只要这本书在手边,就能很轻松地了解和正确使用 Redis 的大部分操作命令了。

不过,如果想要了解最全、最新的 Redis 命令操作,建议你把 Redis 的命令参考网站收录到你的浏览器书签中,随用随查。

目前,Redis 官方提供的所有命令操作参考肯定是最全、最新的,建议优先使用这个官方网站。在这个网页上查找命令操作非常方便,我们既可以通过命令操作的名称直接查找,也可以根据 Redis 的功能,分类查找对应功能下的操作,例如和集群相关的操作,和发布订阅相关的操作。

中文版,提供一个翻译版的命令参考

除了提供 Redis 的命令操作介绍外,《Redis 使用手册》还提供了“附加功能”部分,介绍了 Redis 数据库的管理操作和过期 key 的操作,这对我们进行 Redis 数据库运维(例如迁移数据、清空数据库、淘汰数据等)提供了操作上的指导。

有了工具手册,就能很轻松地掌握不同命令操作的输入参数、返回结果和复杂度了。

2、原理书:《Redis 设计与实现》

虽然《Redis 设计与实现》和《Redis 使用手册》是同一个作者写的,但是它们的侧重点不一样,这本书更加关注 Redis 关键机制的实现原理

介绍 Redis 原理的资料有很多,这本书讲解得非常透彻,尤其是在 Redis 底层数据结构、RDB 和 AOF 持久化机制,以及哨兵机制和切片集群的介绍上,非常容易理解,建议重点学习下这些部分的内容。

除了文字讲解,这本书还针对一些难点问题,例如数据结构的组成、哨兵实例间的交互过程、切片集群实例的交互过程等,都使用了非常清晰的插图来表示,可以最大程度地降低学习难度。

3、实战书:《Redis 开发与运维》

在实战方面,《Redis 开发与运维》是一本不错的参考书。

首先,它介绍了 Redis 的 Java 和 Python 客户端,以及 Redis 用于缓存设计的关键技术和注意事项,这些内容在其他参考书中不太常见,你可以重点学习下。

其次,它围绕客户端、持久化、主从复制、哨兵、切片集群等几个方面,着重介绍了在日常的开发运维过程中遇到的问题和“坑”,都是经验之谈,可以帮助你提前做规避。

另外,这本书还针对 Redis 阻塞、优化内存使用、处理 bigkey 这几个经典问题,提供了解决方案,非常值得一读。

在阅读的时候,可以把目录里的问题整理一下,做成列表,这样,在遇到问题的时候,就可以对照着这个列表,快速地找出原因,并且利用书中的方案去解决问题了。

当然,要想真正提升实战能力,光读书是远远不够的,毕竟,“纸上得来终觉浅”。

两条建议。

  • 阅读源码。读源码其实也是一种实战锻炼,可以帮助你从代码逻辑中彻底理解 Redis 系统的实际运行机制,当遇到问题时,可以直接从代码层面进行定位、分析和解决问题。阅读 Redis 源码,最直接的材料就是 Redis 在 GitHub 上的源码库。另外,有一个网站提供了 Redis 3.0 源码的部分中文注释,你也可以参考一下。

  • 亲自动手实践。“没有服务器无法实践”,其实,Redis 运行后本身就是一个进程,是可以直接使用自己的电脑进行部署的。只要不是性能测试,在功能测试或者场景模拟上,自己电脑的环境一般都是可以胜任的。比如说,要想部署主从集群或者切片集群,模拟主库故障,我们完全可以在自己电脑上起多个 Redis 实例来完成,只要保证它们的端口号不同,就可以了。好了,关于 Redis 本身的书籍的推荐,就先告一段落了,接下来,我想再给你分享一些扩展内容。


二、扩展阅读方向

Redis 的很多关键功能,其实和操作系统底层的实现机制是相关的,比如说,非阻塞的网络框架、RDB 生成和 AOF 重写时涉及到的 fork 和写时复制机制,等等。

另外,Redis 主从集群中的哨兵机制,以及切片集群的数据分布还涉及到一些分布式系统的内容。

一张图片,展示一下 Redis 的关键机制和操作系统、分布式系统的对应知识点。

AOF 日志的刷盘时机和操作系统的 fsync 机制、高速页缓存的刷回有关,而网络框架跟 epoll 有关,RDB 生成和 AOF 重写与 fork、写时复制有关

此外,哨兵选主过程,其实是分布式系统中的经典的 Raft 协议的执行过程,如果你比较了解 Raft 协议,就能很轻松地掌握哨兵选主的运行机制了。

切片集群的 Redis Cluster 方案,其实,业界还有一种实现方案,就是 ShardedJedis,而它就用到了分布式系统中经典的一致性哈希机制。

所以,如果说你希望自己的实战能力能够更强,建议你读一读操作系统分布式系统方面的经典教材,比如《操作系统导论》。

尤其是这本书里对进程、线程的定义,对进程 API、线程 API 以及对文件系统 fsync 操作、缓存和缓冲的介绍,都是和 Redis 直接相关的;

再比如,《大规模分布式存储系统:原理解析与架构实战》中的分布式系统章节,可以让你掌握 Redis 主从集群、切片集群涉及到的设计规范。

了解下操作系统和分布式系统的基础知识,既能帮你厘清容易混淆的概念(例如 Redis 主线程、子进程),也可以帮助将一些通用的设计方法(例如一致性哈希)应用到日常的实践中,做到融会贯通,举一反三。


三、总结

三本参考书,分别对应了 Redis 的命令操作使用关键机制的实现原理,以及实战经验,还介绍了 Redis 操作命令快速查询的两个网站,这可是日常使用 Redis 的必备工具,可以提升你使用操作 Redis 的效率。

另外,对于 Redis 关键机制涉及到的扩展知识点,从操作系统和分布式系统两个方面进行了补充。


如果觉得这些书读起来困难,推荐一本《Redis 深度历险:核心原理与应用实践》,这本书很薄,而且最大的特点是讲解接地气,它可以让你对Redis的基础使用、业务场景、原理分析有一个基本的认识和了解,作为入门和进阶非常合适,起码可以让重新树立起深入学习Redis的信心。

另外,真心建议大家试着去读一下Redis源码,没有想象的那么难,而且Redis的代码质量非常高,由于是单线程的内存数据库,没有多线程运行时的复杂逻辑,读起来非常顺畅!


以上是关于Day768.大佬推荐的经典的Redis学习资料 -Redis 核心技术与实战的主要内容,如果未能解决你的问题,请参考以下文章

软件测试人员必读的经典书籍(附电子书),前阿里大佬给我推荐...

谷歌大佬重磅推荐《Android开发入门精编》,极致经典,堪称Android入门教程的天花板

从字节大佬那要来的,码农的学习书单!

从字节大佬那要来的,码农的学习书单!

Day663.大佬学习经验分享 -Java业务开发常见错误

OMG,阿里P8大佬推荐的10本Java实战书籍Java开发进阶必看