一. redis是什么?
Redis:REmote Dictionary Server(远程字典服务器)
官方解释:
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
二. redis能做什么?
1、主流功能与应用
- 分布式缓存,挡在mysql数据库之前的带刀护卫
与传统数据库关系(mysql)
Redis是key-value数据库(NoSQL一种),mysql是关系数据库
Redis数据操作主要在内存,而mysql主要存储在磁盘
Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
Redis通常用于一些特定场景,需要与Mysql一起配合使用
两者并不是相互替换和竞争关系,而是共用和配合使用
- 内存存储和持久化(RDB+AOF) redis支持异步将内存中的数据写到硬盘上,同时不影响继续服务
- 高可用架构搭配
单机
主从
哨兵
集群
- 缓存穿透、击穿、雪崩
- 分布式锁
- 队列
Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。
我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,
对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。
- 排行版+点赞
在互联网应用中,有各种各样的排行榜,如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。
比如小说网站对小说进行排名,根据排名,将排名靠前的小说推荐给用户
2、一图,总体功能概述
3、优势
-
性能极高 – Redis能读的速度是110000次/秒,写的速度是81000次/秒
-
Redis数据类型丰富,不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储
-
Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用
-
Redis支持数据的备份,即master-slave模式的数据备份
4、小总结
三、去哪下?
1、官网地址
-
英文
https://redis.io/
-
中文
http://www.redis.cn/
中文说明文档
https://www.redis.com.cn/documentation.html
2、下载安装包
https://redis.io/download/
本次Redis7,redis-7.0.0.tar.gz
3、其它文档资料
-
Redis源码地址
https://github.com/redis/redis
中国大陆打开慢 多刷几次或梯子试试 -
Redis在线测试
https://try.redis.io/ -
Redis命令参考
http://doc.redisfans.com/
四、怎么玩?
1、官网
2、多种数据类型基本操作和配置
3、持久化和复制,RDB/AOF
4、事务的控制
5、复制,集群等
五、Redis迭代演化和Redis7新特性浅谈
1、时间推移,版本升级
- Redis之父安特雷兹的发言
http://antirez.com/news/132
2、Redis版本迭代推演介绍
-
几个里程碑式的重要版本
5.0版本是直接升级到6.0版本,对于这个激进的升级,Redis之父antirez表现得很有信心和兴奋,所以第一时间发文来阐述6.0的一些重大功能"Redis 6.0.0 GA is out!":
随后Redis再接再厉,直接王炸Redis7.0—2023年爆款
2022年4月27日Redis正式发布了7.0更新(其实早在2022年1月31日,Redis已经预发布了7.0rc-1,经过社区的考验后,确认没重大Bug才会正式发布) -
命名规则
版本号第二位如果是奇数,则为非稳定版本 如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/
3、Redis7.0新特性概述
-
https://github.com/redis/redis/releases
-
部分新特性总览
2022 年 4 月正式发布的 Redis 7.0 是目前 Redis 历史版本中变化最大的版本。首先,它有超过 50 个以上新增命令;其次,它有大量核心特性的新增和改进。
Redis Functions
Client-eviction
Multi-part AOF
ACL V2
新增命令
listpack替代ziplist
listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)
底层性能提升(和编码关系不大)
4、本次将对Redis7的一部分新特性做说明(not all)
总体概述:
大体和之前的redis版本保持一致和稳定,主要是自身底层性能和资源利用率上的优化和提高,如果你生产上系统稳定,不用着急升级到最新的redis7版本,当然,O(∩_∩)O哈哈~,如果你是从零开始的新系统,直接上Redis7.0-GA版。_