目录
一、Redis入门概述
1. 是什么?
官方解释:
2. 能干嘛?
2.1 主流功能与应用
2.1.1分布式缓存
2.1.2内存存储和持久化(RDB+AOF)
2.1.3高可用架构搭建
2.1.4缓存穿透、击穿、雪崩
2.1.5分布式锁
2.1.6队列
2.2 总体功能概括
2.3 优势
3. 去哪下?
官网地址:
英文:
中文:
中文文档:
下载安装包:
其他文档资料:
Redis源码地址:
Redis在线测试:
Redis命令参考:
4. 怎么玩?
5.Redis迭代演化和Redis7新特性
5.1 版本迭代推演介绍
5.1.1 里程碑版本
5.1.2 命名规则
5.2 Redis7.0新特性概述
5.2.1 Redis Functions
5.2.2 Client-eviction
5.2.3 Multi-part AOF
5.2.4 ACL V2
5.2.5 新增命令
5.2.6 listpack替代ziplist
5.2.7 底层性能提升(和编码关系不大)
5.3 总结概括
Redis 全名:Remote Dictionary Server
一、Redis入门概述
1. 是什么?
官方解释:
Remote Dictionary Server(远程字典服务)是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、sortedset等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存海汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案
Redis之父特雷兹
2. 能干嘛?
2.1 主流功能与应用
2.1.1分布式缓存
挡在MySQL数据库之前的带刀护卫
与传统的数据库关系(mysql)
Redis是key-value数据库(NOSQL一种),mysql是关系数据库
Redis数据操作主要在内存,而mysql主要存储在磁盘
Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
Redis通常用于一些特定场景,需要与Mysql一起配合使用
两者并不是相互替换和竟争关系,而是共用和配合使用
2.1.2内存存储和持久化(RDB+AOF)
redis支持异步将内存的数据写到硬盘上,同时不影响继续服务
虽然Redis是基于内存运行 的,但是也支持redis自身的数据持久化到硬盘里,因为如果Redis关闭或者宕机数据没有保存,下次查询的时候还得麻烦MySQL数据库,就比较消耗内存,写到硬盘里的东西还可以直接恢复到Redis,不麻烦MySQL
2.1.3高可用架构搭建
单机
主从
哨兵
集群:集群Redis的好处就是,当一台Redis挂掉之后,其他Redis可以顶上,不耽误Redis的工作
2.1.4缓存穿透、击穿、雪崩
如果只有一个Redis的话,当这一台Redis挂掉之后,client查询数据又变成直接向MySQL查询,这时候就容易造成缓存穿透、击穿、雪崩
2.1.5分布式锁
MySQL的是JVM,Redis需要跨服务器实现功能,需要加速,Redis也可以做到
2.1.6队列
Redis有各种各样的数据类型,比如string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。
Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。
-
set是无序的,人们生活中使用的验证码也是无序的,当发送验证码的时候,用Redis快
我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。
在互联网应用中,有各种各样的排行榜,如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。比如小说网站对小说进行排名,根据排名,将排名靠前的小说推荐给用户
2.2 总体功能概括
拥有十大数据类型,可以用作高可用,高性能的操作
支持持久化,Forking-->fork() 单独的备份
支持Redis Cluster 集群
哨兵:Redis 安装完毕后 直接是主从结构 ,主机挂掉之后,可以在从机里找一台上位变更
2.3 优势
性能极高 — Redis能读的速度是110000次/秒写的速度是81000次/秒
Redis数据类型丰富,不仅仅支持简单的key-value类型的数据同时还提供list,set,zset,hash等数据结构的存储
Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
Redis支持数据的备份,即master-slave模式的数据备份
3. 去哪下?
官网地址:
英文:
https://redis.io/
中文:
(大佬翻译,是英文官方的映射,版本知识可能会落后一点)
http://www.redis.cn/
中文文档:
https://www.redis.com.cn/documentation.html
下载安装包:
https://redis.io/download/
其他文档资料:
Redis源码地址:
https://github.com/redis/redis
Redis在线测试:
https://try.redis.io/
Redis命令参考:
http://doc.redisfans.com
4. 怎么玩?
多种数据类型基本操作和配置
持久化和复制,RDB/AOF
事务的控制
复制,集群等
5.Redis迭代演化和Redis7新特性
5.1 版本迭代推演介绍
5.1.1 里程碑版本
5.1.2 命名规则
版本号第二位如果是奇数,则为非稳定版本 如2.7、2.9、3.1
版本号第二位如果是偶数,则为稳定版本 如2-6、2.8、3.0、3.2
5.2 Redis7.0新特性概述
5.2.1 Redis Functions
更高效更易用更好管理
5.2.2 Client-eviction
连接内存占用独立管理
5.2.3 Multi-part AOF
Redis的持久化:RDB 和 AOF
7.0之前AOF有且只有一个,7.0AOF变成了多个
AOFRW不再是运维痛点
5.2.4 ACL V2
精细化权限管理
5.2.5 新增命令
新增ZMPOPBZMPOP,LMPOP BLMPOP等新命令,对于EXPIRE和SET命令,新增了更多的命令参数选项。
例如,ZMPOP的格式如下: ZMPOP numkeys key [key ...]MIN|MAX[COUNT count],而BZMPOP是ZMPOP的阻塞版本。
5.2.6 listpack替代ziplist
跳表,压缩包等
7.0 没有了ziplist