当前位置: 首页 > news >正文

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的代码质量非常高,由于是单线程的内存数据库,没有多线程运行时的复杂逻辑,读起来非常顺畅!


相关文章:

  • fastdfs简介及在springboot中使用
  • OpenCASCADE使用(Stp to Gltf)
  • 进程互斥的硬件实现方式【操作系统学习笔记】
  • JavaScript教程-原生的原型,Object.prototype,其他的内建原型,从原型当中借用,原型方法,_proto_
  • (Java岗)秋招打卡!一本学历拿下美团、阿里、快手、米哈游offer
  • 基于微信小程序的数码商城程序设计与实现(后台PHP+Mysql)
  • FA_06.不用刷机情况下升级或者降级系统中的fridaserver
  • 【笔试题】【day3】
  • 微信小程序|基于小程序实现人脸识别对比
  • [附源码]Java计算机毕业设计SSMJava商场会员管系统
  • 多模态学习、迁移学习、元学习、联邦学习、表示学习、知识图谱、无监督学习、半监督学习、弱监督学习、自监督学习简介
  • 剑指offer 63. 和为S的两个数字
  • 【VUE基础】webpack
  • 机器人轨迹规划中经常用到的曲线特性小结:Cn连续与Gn连续、Frenet标架、曲率和挠率
  • 【深度学习】卷积神经网络CNN入门介绍
  • [分享]iOS开发-关于在xcode中引用文件夹右边出现问号的解决办法
  • 08.Android之View事件问题
  • cookie和session
  • LintCode 31. partitionArray 数组划分
  • puppeteer stop redirect 的正确姿势及 net::ERR_FAILED 的解决
  • Shell编程
  • Spring Cloud Feign的两种使用姿势
  • UMLCHINA 首席专家潘加宇鼎力推荐
  • 从PHP迁移至Golang - 基础篇
  • 从零搭建Koa2 Server
  • 仿天猫超市收藏抛物线动画工具库
  • 经典排序算法及其 Java 实现
  • 类orAPI - 收藏集 - 掘金
  • 前端面试之CSS3新特性
  • 深度解析利用ES6进行Promise封装总结
  • 什么软件可以提取视频中的音频制作成手机铃声
  • 微信如何实现自动跳转到用其他浏览器打开指定页面下载APP
  • kubernetes资源对象--ingress
  • 新年再起“裁员潮”,“钢铁侠”马斯克要一举裁掉SpaceX 600余名员工 ...
  • ### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.CommunicationsException
  • #微信小程序:微信小程序常见的配置传值
  • ( )的作用是将计算机中的信息传送给用户,计算机应用基础 吉大15春学期《计算机应用基础》在线作业二及答案...
  • (02)Cartographer源码无死角解析-(03) 新数据运行与地图保存、加载地图启动仅定位模式
  • (16)Reactor的测试——响应式Spring的道法术器
  • (23)Linux的软硬连接
  • (Java实习生)每日10道面试题打卡——JavaWeb篇
  • (python)数据结构---字典
  • (Redis使用系列) Springboot 使用redis的List数据结构实现简单的排队功能场景 九
  • (带教程)商业版SEO关键词按天计费系统:关键词排名优化、代理服务、手机自适应及搭建教程
  • (独孤九剑)--文件系统
  • (附源码)spring boot网络空间安全实验教学示范中心网站 毕业设计 111454
  • (十八)SpringBoot之发送QQ邮件
  • (十二)springboot实战——SSE服务推送事件案例实现
  • (转)菜鸟学数据库(三)——存储过程
  • (轉貼) UML中文FAQ (OO) (UML)
  • .NET 8.0 发布到 IIS
  • .NET 使用配置文件
  • .Net程序猿乐Android发展---(10)框架布局FrameLayout
  • .net图片验证码生成、点击刷新及验证输入是否正确
  • .Net中wcf服务生成及调用