蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

前言

什么是redis?

Redis 是一个基于内存的高性能key-value数据库。

Redis本质上是一个Key-Value类型的内存数据库,很像memcached,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内存操作,Redis的性能非常出色,每秒可以处理超过 10万次读写操作,是已知性能最快的Key-Value DB。

本文总共分为3个部分对Redis进行“解剖”:

  • 第一部分对Redis进行了基本介绍,并展示了一些Redis的使用示例;
  • 第二部分对Redis的多个命令进行了详细的介绍,之后还介绍了Redis 的管理操作以及使用Redis构建更复杂的应用程序的方法;
  • 第三部分介绍了如何通过内存优化、水平分片以及Lua脚本这3种技术来扩展Redis。

如果需要获取到这个【Redis文档】文档的话评论留言+转发文章+关注我后私信回复【Java】即可免费获取这份文档资料!

一、Redis入门

入门简介:对于Redis数据库的描述只说出了一部分真相,Redis是-一个速度非常快的非关系数据库( non-relational database),它可以存储键(key) 与5种不同类型的值( value)之间的映射(mapping),可以将存储在内存的键值对数据持久化到硬盘,可以使用复制特性来扩展读性能,还可以使用客户端分片来扩展写性能,接下来的几节将分别介绍Redis的这几个特性。

Redis目录如下图

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

关于Redis与其他数据库和软件的对比

下图展示了部分在功能上与Redis有重叠的数据库服务器和缓存服务器,从这个表可以看出Redis与这些数据库及软件之间的区别。

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

第一部分关于详细介绍由于文案篇幅过长就不详细在文中展示

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库


二、Redis的核心概念

这一部分的前面几章将深人探讨标准的 Redis命令,其中包括 数据操作命令和配置命令,而后面的几章将展示如何使用Redis构建更为复杂的辅助工具和应用程序,并在最后使用Redis来构建一个简单的社交网站。

Redis目录如下图

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

这部分可以配合一些Redis面试题一起使用,边学边思考!

redis事物的了解CAS(check-and-set 操作实现乐观锁 )?

redis的并发竞争问题如何解决?

Redis是单进程单线程的

请用Redis和任意语言实现一段恶意登录保护的代码,限制1小时内每用户Id最多只能登录5次。具体登录函数或功能用空函数即可,不用详细写出。

为什么redis需要把所有数据放到内存中? 

三、Redis进阶内容

这个部分需要思考的面试题!

Redis回收进程如何工作的?

Redis如何做内存优化?

Redis key的过期时间和永久有效分别怎么设置?

Redis事务相关的命令有哪几个?

怎么理解Redis事务?

Redis中的管道有什么用?

怎么测试Redis的连通性?

最后的这几章将对Redis用户经常会遇到的一-些问题进行介绍(降低内存占用、扩展性能、使用Lua语言进行脚本编程),并说明如何使用常规的技术去解决这些问题。

目录如下图:

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

3.1.降低内存占用

短结构( short structure )、分片结构( shared structure )、打包存储二进制位和字节

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

3.2.扩展Redis

扩展读性能、扩展写性能以及内存容量、扩展复杂的查询

扩展性能图如下:

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

3.3.Redis的Lua脚本编程

在不编写C代码的情况下添加新功能、使用Lua重写锁和信号量、移除WATCH/MULTI/EXEC事务、使用Lua对列表进行分片

Redis的Lua脚本如下图:

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

Redis实战书籍

蚂蚁金服架构师这一份PDF,带着你由浅入深,彻底掌握Redis数据库

如果需要获取到这个【Redis文档】文档的话评论留言+转发文章+关注我后私信回复【Java】即可免费获取这份文档资料!

相关推荐