1、什么是Redis
Remote Dictionary Server(远程字典服务)是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、SortedSet等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案
历史版本的官网
最新版官网
Redis之父Salvatore Sanfilippo,一名意大利程序员,大家更习惯称呼他Antirez
Github:https://github.com/antirez
个人博客:http://antirez.com/latest/0
2、Redis 能做什么
2.1、分布式缓存
- 与传统数据库关系(mysql)
- Redis是key-value数据库(NoSQL一种),mysql是关系数据库
- Redis数据操作主要在内存,而mysql主要存储在磁盘
- Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
- Redis通常用于一些特定场景,需要与Mysql一起配合使用
- 两者并不是相互替换和竞争关系,而是共用和配合使用
2.2、内存存储与持久化(RDB+AOF)
Redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务。
2.3、高可用架构搭建
单机、主从、哨兵、集群
2.4、缓存穿透、击穿、雪崩
2.5、分布式锁
2.6、队列
Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。
我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。
2.7、实现排行榜、点赞等功能
优势
性能极高 - Redis读的速度是110000次/秒,写的速度是81000次/秒。
数据类型丰富,不仅仅支持k-v类型的数据,同时还提供了list、set、zset、hash等数据结构的存储。
支持持久化,可将内存中的数据存入写入到磁盘中。
支持数据备份,即master-slaver模式的数据备份
2.8、一图流概括介绍:
2.9、优势
- 性能极高
- 数据类型丰富,不仅仅支持简单的key-value,同时还提供list、set、zset、hash等数据结构的存储
- 支持持久化
- 支持数据的备份
2.10、小总结
3、Redis在线文档地址
官网地址
英文:Redis 官网地址
中文:
Redis中文学习网 - Redis开发与运维技术、Redis教程、使用手册
在线测试地址:在线测试地址
Redis命令参考:Redis 命令参考 — Redis 命令参考
源代码地址:redis源代码地址 (可能需要翻墙)
下载安装包地址:下载 - Redis
7.0版本、6.2版本下载
4、Redis迭代演化和Redis7新特性
4.1、里程碑重要版本
5.0版本是直接升级到6.0版本,对于这个激进的升级,Redis之父antirez表现得很有信心和兴奋,
(其实早在2022年1月31日,Redis已经预发布了7.0rc-1,经过社区的考验后,确认没重大Bug才会正式发布)
4.2、版本命名规则
Redis从发布至今,已经有十余年的时光了,一直遵循着自己的命名规则:
版本号第二位如果是奇数,则为非稳定版本 如2.7、2.9、3.1
版本号第二位如果是偶数,则为稳定版本 如2.6、2.8、3.0、3.2
当前奇数版本就是下一个稳定版本的开发版本,如2.9版本是3.0版本的开发版本
我们可以通过redis.io官网来下载自己感兴趣的版本进行源码阅读:
历史发布版本的源码:https://download.redis.io/releases/
4.3、Redis7.0新特性概述
4.3.1、Redis Functions
4.3.2、Client-eviction
4.3.3、Multi-part AOF
4.3.4、ACL V2
4.3.5、新增命令
4.3.6、listpack代替ziplist
listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)
总体概述:
大体和之前的redis版本保持一致和稳定,主要是自身底层性能和资源利用率上的优化和提高,如果你生产上系统稳定,不用着急升级到最新的redis7版本,当然,O(∩_∩)O哈哈~,如果你是从零开始的新系统,直接上Redis7.0-GA版。^_^
多AOF文件支持 | 7.0 版本中一个比较大的变化就是 aof 文件由一个变成了多个,主要分为两种类型:基本文件(base files)、增量文件(incr files),请注意这些文件名称是复数形式说明每一类文件不仅仅只有一个。在此之外还引入了一个清单文件(manifest) 用于跟踪文件以及文件的创建和应用顺序(恢复) |
config命令增强 | 对于Config Set 和Get命令,支持在一次调用过程中传递多个配置参数。例如,现在我们可以在执行一次Config Set命令中更改多个参数: config set maxmemory 10000001 maxmemory-clients 50% port 6399 |
限制客户端内存使用
Client-eviction
| 一旦 Redis 连接较多,再加上每个连接的内存占用都比较大的时候, Redis总连接内存占用可能会达到maxmemory的上限,可以增加允许限制所有客户端的总内存使用量配置项,redis.config 中对应的配置项
// 两种配置形式:指定内存大小、基于 maxmemory 的百分比。
maxmemory-clients 1g
maxmemory-clients 10%
|
listpack紧凑列表调整 | listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)listpack 已经替换了 ziplist 类似 hash-max-ziplist-entries 的配置 |
访问安全性增强ACLV2 | 在redis.conf配置文件中,protected-mode默认为yes,只有当你希望你的客户端在没有授权的情况下可以连接到Redis server的时候可以将protected-mode设置为no |
Redis Functions | Redis函数,一种新的通过服务端脚本扩展Redis的方式,函数与数据本身一起存储。
简言之,redis自己要去抢夺Lua脚本的
|
RDB保存时间调整 | 将持久化文件RDB的保存规则发生了改变,尤其是时间记录频度变化 |
命令新增和变动 | Zset (有序集合)增加 ZMPOP、BZMPOP、ZINTERCARD 等命令
Set (集合)增加 SINTERCARD 命令
LIST (列表)增加 LMPOP、BLMPOP ,从提供的键名列表中的第一个非空列表键中弹出一个或多个元素
|
性能资源利用率、安全、等改进 | 自身底层部分优化改动,Redis核心在许多方面进行了重构和改进
主动碎片整理V2:增强版主动碎片整理,配合Jemalloc版本更新,更快更智能,延时更低
HyperLogLog改进:在Redis5.0中,HyperLogLog算法得到改进,优化了计数统计时的内存使用效率,7更加优秀
更好的内存统计报告
|