Redis00_理论介绍

PS:最近在跟SGG的杨老师学习redis 觉得他上课用的笔记不太适合新手,所以在学习的过程中同步更新md版本的,图片均来自杨老师。

一、Redis是什么?

​ Remote Dictionary Server(远程字典服务):是完全开源的,使用ANSIC语言编写遵守BSD协议,是一个高性能的Key-Value数据库提供了丰富的数据结构,例如String、Hash、List、Set、SortedSet等等。数据是存在内存中的,同时Redis支持事务、持久化、LUA脚本、发布/订阅、缓存淘汰、流技术等多种功能特性提供了主从模式、Redis Sentinel和Redis Cluster集群架构方案

Redis之父Salvatore Sanfilippo,一名意大利程序员,大家更习惯称呼他Antirez(安特雷兹)

​ https://github.com/antirez 安特雷兹Github

​ http://antirez.com/latest/0 安特雷兹个人博客

官网:https://redis.io (全英文的)在这里插入图片描述

http://www.redis.cn/(中文)

二、Redis能干嘛

1.主流功能与应用

(1)基于内存的key-value键值对

(2)分布式缓存 挡在数据仓库MySQL前的带刀侍卫

在这里插入图片描述
redis与传统数据库关系(mysql)
Redis是key-value数据库(NoSQL一种),mysql是关系数据库
Redis数据操作主要在内存,而mysql主要存储在磁盘
Redis在某一些场景使用中要明显优于mysql,比如计数器、排行榜等方面
Redis通常用于一些特定场景,需要与Mysql一起配合使用
两者并不是相互替换和竞争关系,而是共用和配合使用

(3)内存存储和持久化(RDB + AOF)

 Redis支持异步将内存中的数据写到硬盘中,同时不影响继续服务

(4)高可用架构搭配

单机、主从、哨兵、集群

(5)缓存穿透、击穿、雪崩

(6)分布式锁

(7)队列

Reids提供list和set操作,这使得Redis能作为一个很好的消息队列平台来使用。
我们常通过Reids的队列功能做购买限制。比如到节假日或者推广期间,进行一些活动,
对用户购买行为进行限制,限制今天只能购买几次商品或者一段时间内只能购买一次。也比较适合适用。

(8)排行榜、抢红包、朋友圈点赞

排行榜 + 点赞
在互联网应用中,有各种各样的排行榜,如电商网站的月度销量排行榜、社交APP的礼物排行榜、小程序的投票排行榜等等。Redis提供的zset数据类型能够快速实现这些复杂的排行榜。
比如小说网站对小说进行排名,根据排名,将排名靠前的小说推荐给用户

一图总览redis功能
在这里插入图片描述

2.优势

(1)性能极高

性能极高 – Redis能读的速度是110000次/秒,写的速度是81000次/秒

(2)数据类型丰富

Redis数据类型丰富,不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储

(3)持久化

Redis支持数据的持久化,可以将内存中的数据保持在磁盘中,重启的时候可以再次加载进行使用

(4)支持数据备份

 master-slave模式的数据备份

三、去哪下

1、官网地址

https://redis.io (全英文的)

http://www.redis.cn/(中文)

www.redis.com.cn/documentation.html(中文文档)

2、下载安装包

下载网址:https://redis.io/download/
在这里插入图片描述

以下载(redis-7.0.23.tar.gz)为例

官网下载的慢的 这里提供网盘下载:链接:https://pan.baidu.com/s/11Hx_IbZ75c-2dRureB2X2Q?pwd=jre2

3、其他文档

redis源码地址:https://github.com/redis/redis(中国大陆的可能会打开的慢一些)
在这里插入图片描述

Redis在线测评:https://try.redis.io(自己本机没有Linux虚拟机或者安装Redis失败的可以以在线访问现成的)

在这里插入图片描述

Redis命令参考:http://doc.redisfans.com/

在这里插入图片描述

四、怎么玩

1.官网

先看官网介绍
在这里插入图片描述

2.多种数据类型基本操作和配置

3.持久化和复制

4.事务的控制

5.复制、集群

五、Redis迭代演化和Redis7新特性

1.时间推移 版本升级

Redis之父安特雷兹的发言:http://antirez.com/news/132

2.Redis版本迭代推演介绍

(1)里程碑式的版本更新

在这里插入图片描述

1.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.一个小小的冷知识
版本号第二位如果是奇数,则为非稳定版本 如2.7、2.9、3.1
版本号第二位如果是偶数,则为稳定版本 如2.6、2.8、3.0、3.2
当前奇数版本就是下一个稳定版本的开发版本,如2.9版本是3.0版本的开发版本
(上方网盘链接是7.2.2 所以是稳定版)

历史发布的版本:https://download.redis.io/releases/

在这里插入图片描述

3.Redis7.0新特性(Not All)

在这里插入图片描述

(1) Redis Functions

redis内部的lua脚本

在这里插入图片描述

(2)Client-evicition

连接内存占用独立管理 保证更多的人连接上

在这里插入图片描述

(3) Multi-part AOF

AOF RW 不再是痛点

在这里插入图片描述

(4)ACL V2

在这里插入图片描述

(5)新增命令

在这里插入图片描述

(6)listpack替代ziplist

listpack 是用来替代 ziplist 的新数据结构,在 7.0 版本已经没有 ziplist 的配置了(6.0版本仅部分数据类型作为过渡阶段在使用)

在这里插入图片描述

(7)底层性能提升

在这里插入图片描述

Redis7的一部分新特性说明

总体概述:
大体和之前的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。
限制客户端内存使用一旦 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 FunctionsRedis函数,一种新的通过服务端脚本扩展Redis的方式,函数与数据本身一起存储。
简言之,redis自己要去抢夺Lua脚本的饭碗。
RDB保存时间调整将持久化文件RDB的保存规则发生了改变,尤其是时间记录频度变化。
命令新增和变动Zset (有序集合)增加 ZMPOP、BZMPOP、ZINTERCARD 等命令。
Set (集合)增加 SINTERCARD 命令。
LIST (列表)增加 LMPOP、BLMPOP ,从提供的键名列表中的第一个非空列表键中弹出一个或多个元素。
性能资源利用率、安全、等改进自身底层部分优化改动,Redis核心在许多方面进行了重构和改进。
主动碎片整理V2:增强版主动碎片整理,配合Jemalloc版本更新,更快更智能,延时更低。
HyperLogLog改进:在Redis5.0中,HyperLogLog算法得到改进,优化了计数统计时的内存使用效率,7更加优秀。
更好的内存统计报告。
如果不为了API向后兼容,我们将不再使用slave一词…(政治正确)

想获取文件的md版本的兄弟们,欢迎关注我的个人公众号:daxue230505(大学生成长之路)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值