蚂蚁金服架构师这一份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目录如下图
关于Redis与其他数据库和软件的对比
下图展示了部分在功能上与Redis有重叠的数据库服务器和缓存服务器,从这个表可以看出Redis与这些数据库及软件之间的区别。
第一部分关于详细介绍由于文案篇幅过长就不详细在文中展示
二、Redis的核心概念
这一部分的前面几章将深人探讨标准的 Redis命令,其中包括 数据操作命令和配置命令,而后面的几章将展示如何使用Redis构建更为复杂的辅助工具和应用程序,并在最后使用Redis来构建一个简单的社交网站。
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语言进行脚本编程),并说明如何使用常规的技术去解决这些问题。
目录如下图:
3.1.降低内存占用
短结构( short structure )、分片结构( shared structure )、打包存储二进制位和字节
3.2.扩展Redis
扩展读性能、扩展写性能以及内存容量、扩展复杂的查询
扩展性能图如下:
3.3.Redis的Lua脚本编程
在不编写C代码的情况下添加新功能、使用Lua重写锁和信号量、移除WATCH/MULTI/EXEC事务、使用Lua对列表进行分片
Redis的Lua脚本如下图:
Redis实战书籍
如果需要获取到这个【Redis文档】文档的话评论留言+转发文章+关注我后私信回复【Java】即可免费获取这份文档资料!