Redis探索之旅

news2024/11/24 7:33:40

目录

今日良言:有志者自有千计万计,无志者只感千难万难

一、简介

二、Redis的安装

三、Redis的简单使用

四、Redis相关知识点

1.缓存分类

2.五大基本数据类型使用

3.持久化

4.常见面试题


今日良言:有志者自有千计万计,无志者只感千难万难

一、简介

先来介绍一下什么是缓存

缓存是一个高速数据交换的存储器,使用它可以快速的访问和操作数据。

对于程序来说,如果没有使用缓存,程序的调用流程如下:

但是,随着公司的业务发展,逐步变成了多个程序调用一个数据库的情况了:

当公司业务发展到一定规模之后,最可能出现性能拼劲的地方就是数据库了,为了防止数据库被过渡的浪费,就引入了缓存,避免程序直接访问数据库,,加入缓存后,流程如下:

加入缓存以后,所有的程序不会直接调⽤数据库,而是会先调用缓存,当缓存中有数据时会直接返回,当缓存中没有数据时才去查询数据库,这样就大大的降低了数据库的压力,并加速了程序的响应速度。

 缓存优点:

1. 缓存一般都是使用key-value 查询数据的,因为不像数据库还有查询的条件等因素,所以查询的性能一般会比数据库高。

2. 缓存的数据是存储在内存的,而数据库的数据是存储在磁盘中的,因为内存的操作性能远远大于磁盘,因此缓存的查询效率会高很多;

3.缓存更容易做分布式部署,而数据库很难实现分布式部署,因此缓存的负载和性能更适合平行扩展和增加。

Redis 是常见的分布式缓存。

二、Redis的安装

1. yum 命令安装 redis

 使用以下命令,直接将 redis 安装到 linux 服务器:

yum -y install redis  

 2. 启动 redis

使用以下,以后台运行方式启动 redis

redis-server /etc/redis.conf &

这里的redis.conf 是redis的配置文件,可以在这个配置文件中修改 redis的相关配置

3. 操作redis

使用以下命令启动 redis 客户端:

redis-cli  

如果修改了 redis 的默认端口号6379,启动 redis 客户端使用如下命令:

redis-cli -p xxxx

-p后面是修改后的端口号

4. 设置远程连接

1)将 redis 配置文件下载到本地:redis 配置文件是 linux 下的 /etc/redis.conf

先切到 etc 目录下,然后找redis.conf 文件

 

2)将 redis.conf 配置文件中的 “bind 127.0.0.1” 注释。

打开 redis.conf 文件,然后找到 bind 127.0.0.1 并注释

 3)将 redis.conf 中的“protected-mode yes” 改为“protected-mode no”

4.将修改后的 redis.conf 文件上传到 etc目录下

5.使用 命令 redis-cli shutdown 先关闭服务, 再使用 redis-server /etc/redis.conf 启动 redis 服务

 注:

远程连接后,redis 的默认端口容易被入侵,云服务器也会被入侵,这就导致会有人使用你的服务器攻击别人,如下图:(博主被搞了好久,天天攻击别人)

 所以,为了安全起见,可以修改一下 redis 的端口,还是下载 redis.conf 文件,然后修改里面配置,找到 port,修改默认端口 6379 为别的端口:

修改了端口号以后,需要在云服务器的防火墙那里开放这个端口。 

 然后再新增一个密码:

找到   requirepass foobared  然后注释掉,再新增:

requirepass 你的密码

 然后再重复 上述 4)  5) 步。

此时,使用 redis-cli -p 端口号 打开客户端:

 此时还需要输入密码:

auth 后面跟上刚才新增的密码

出现 OK 后,即可使用本地redis 

 

 可以使用如下软件远程连接 redis:

 

打开后:

 

 然后即可连接成功。

三、Redis的简单使用

四、Redis相关知识点

1.缓存分类

缓存大致可以分类两类:

本地缓存

本地缓存也叫单机缓存,也就是说可以应用在单机环境下的缓存。所谓的单机环境是指,将服务部署到⼀台服务器上,如下图:

本地缓存的特征是只适用于当前系统。
常见本地缓存有:Spring Cache、MyBatis 的缓存等。

分布式缓存

分布式缓存是指可以应⽤在分布式系统中的缓存。所谓的分布式系统是指将⼀套服务器部署到多台服务器,并且通过负载分发将⽤户的请求按照⼀定的规则分发到不同服务器,如下图:

 常见的分布式缓存有: Redis 和 Memcached。

Redis 和 Memcached 的区别如下:

1. 存储方式不同:memchched 把数据全部存到内存之中,断电后会挂掉,数据不能超过内存大小。redis 有部分存到硬盘中,这样能保持数据的持久性。

2. 数据支持类型: memcached 对数据类型支持相对简单,redis 有复杂的数据类型。

3. 存储值大小不同:redis 最大可以达到 512mb,memcached 只有 1mb。

通常情况下,如果是单机 Spring 项⽬,会直接使⽤ Spring Cache 作为本地缓存,如果是分布式环境⼀般会使⽤ Redis。

2.五大基本数据类型使用

Redis 有五大基本数据类型:

String     字符串类型

Hash      字典类型

List         列表类型

Set         集合类型

ZSet       有序集合类型

其中最常用的是 字符串类型和 字典类型。

String     字符串类型

字符串类型,它是以键值对 key-value 的形式进行存储的,根据 key 值获取 value 值,它的使用相对比较简单,但是实际项目中应用非常广泛。
字符串的使用如下:

 

Hash      字典类型

字典类型又被称为散列表或者是哈希表类型,它是将一个键值 key 和一个特殊的“哈希表”关联起来,这个“哈希表”包含两列数据:字段和值,它就相当于 Java 中的 Map<String,Map<String,String>> 结构,同时,这里的字典类型又很像 Java 中的会话。

字典类型的使用如下:

通常情况下,字典类型会使用数组的方式来存储相关的数据,但发生哈希冲突时才会用链表的结构来存储数据。

List         列表类型

列表类型是一个使用链表结构存储的有序结构,它的元素插入会按照先后顺序存储到链表结构中,因此它的元素操作(插入和删除),时间复杂度为O(1),所以相对而言它的速度还是比较快的,但是它的查询操作的时间复杂度为 O(n),因此查询可能会比较慢。

列表类型的使用如下:

 列表的典型使用场景有两个:

1)消息队列

2)文章列表

Set         集合类型

集合类型 是一个无序并唯一的键值集合。

集合类型的使用如下:

集合类型和列表类型的区别如下:

1)列表可以存储重复元素,集合只能存储非重复元素。

2)列表是按照先后顺序存储元素的,而集合是无序方式存储元素的。

ZSet       有序集合类型

有序集合类型(Sorted Set)相比于集合类型多了一个排序属性 score(分值),对于有序集合 ZSet 来说,每个存储元素相当于有两个值组成的,一个是有序集合的元素值,一个是排序值。有序集合的存储元素值是不能重复的,但分值是可以重复的。

有序集合类型的使用如下:

有序集合的使用场景如下:

1)学生成绩排名。

2)粉丝列表,根据关注的先后时间排序。 

3.持久化

所谓的持久化,就是将数据从内存保存到磁盘的过程,它的目的就是为了防止数据丢失。

redis 的持久化方式有三种:

1)快照方式(RDB,Redis DataBase)

将某一时刻的内存数据,以二进制的方式写入磁盘。

RDB 的优点:

a)RDB 的内容为二进制的数据,占用内存更少,更紧凑,更适合做备份文件。

b)RDB 对容灾恢复非常有用,它是一个紧凑的文件,可以更快的传输到远程服务器进行 Redis 服务恢复。

c)与AOF 的格式相比,RDB 文件可以更快的重启。

RDB 的缺点:

a)因为 RDB 只能保存某个时间间隔的数据,如果中途 Redis 服务被以外终止了,则会丢失一段时间的 Redis 数据。

b)RDB 需要经常 fork() 才能使用子进程将其持久化到磁盘上,如果数据集很大,fork() 可能很耗时,并且,如果数据集很大且 CPU 性能不佳,则会导致 Redis 停止为客户端服务几毫秒甚至一秒钟。

2)文件追加方式(AOF,Append Only File) 

记录所有的操作命令,并以文本的形式追加到文件中。

AOF 的优点:

a)AOF 持久化保存的数据更加完整,AOF 提供了三种保存策略:每次操作保存、每秒钟保存一次、跟随系统的持久化策略保存,其中每秒保存一次,从数据的安全性和性能两方面考略是一个不错的选择,也是 AOF 默认的策略,即使发生了意外情况,最多只会丢失 1 s的数据。

b)AOF 采用的是子命令追加的写入方式,所以不会出现文件损坏的问题,即使由于某些以外原因,导致了最后操作的持久化数据写⼊了⼀半,也可以通过 redis-check-aof 工具轻松的修复。

c)AOF 持久化文件,非常容易理解和解析,它是把所有的 Redis 键值操作命令,以文件的方式存入了磁盘,即使不小心使用 fullshall 命令删除了所有键值信息,只要 AOF 文件,删除最后的 fullshall 命令,重启 Redis 即可恢复之前误删的数据。

AOF 的缺点:

a)对于相同的数据集来说,AOF 文件要大于 RDB 文件。

b)在 Redis 负载比较高的情况下,RDB 比 AOF 性能更好。

c)RDB 使用快照的形式来持久化整个 Redis 数据,而 AOF 只是将每次执行的命令追加到 AOF 文件中,因此,RDB 比 AOF 文件更健壮。

3)混合持久化方式

Redis 4.0 之后新增的方式,混合持久化是结合了 RDB 和 AOF 的优点,在写入的时候,先把当前的数据 以 RBD 的形式写入文件的开头,再将后续的操作命令以 AOF 的形式存入文件,这样既能保证 Redis 重启时的速度,又能降低数据丢失的风险。

混合持久化的优点:

结合了 RDB 和 AOF 的优点,开头为 RDB 的格式,使得 Redis 可以更快的启动,同时结合了 AOF 的优点,降低了大量数据丢失的风险。

混合持久化的缺点:

a)AOF 文件中添加了 RDB 格式的内容,使得 AOF 文件的可读性变得很差。

b)兼容性差,如果开启混合持久化,那么此混合持久化 AOF 文件,就不能用在 Redis 4.0 之前的版本。

4.常见面试题

接下来,介绍一下Redis 的相关面试题:

1)缓存雪崩

缓存雪崩指的是在短时间内,大量缓存同时过期,导致大量的用户请求直接操作数据库,从而对数据库造成了很大的压力,严重情况下可能会导致数据库宕机,这种情况称为缓存雪崩。

缓存雪崩的解决方案:

a)加锁排队

加锁排队可以起到缓冲的作用,方式大量的用户请求同时操作数据库,但它的缺点是增加了系统的响应时间,降低了系统的并发量,牺牲了一部分用户的体验。

b)随机化过期时间

为了避免缓存同时过期,在设置缓存的时候,添加随机过期时间,这样就可以极大的避免大量缓存同时失效。        

c)设置二级缓存

二级缓存指的是:除了 Redis 本身的缓存之外,再设置一层缓存,当 Redis 失效之后,先去查询二级缓存,并非直接查询数据库。

2)缓存穿透

缓存穿透指的是:查询缓存和数据库无结果,由于数据库查询无结果,出于容错考虑,不会将结果保存到缓存中,因此每次请求都会去查询数据,这种情况就叫做缓存穿透。

缓存穿透的解决方案:

缓存空结果

每次将数据库查询的数据都保存到缓存中,为了提高前台用户的使用体验(解决长时间内查询不到任何信息的情况),可以将空结果的缓存时间设置的短一些,例如:3-5分钟。

3)缓存击穿

缓存击穿指的是:某一热点缓存,在某一时刻过期,此时大量用户请求直接操作数据库,会给数据库造成巨大的压力,这种情况就叫做缓存击穿。

缓存击穿的解决方案:

a)加锁排队

和解决缓存雪崩的加锁排队的方法类似,都是在查询数据库的时候加锁排队,避免大量用户同时请求数据库,以此来减少数据库的压力。

b)设置永不过期

对于热点缓存,可以设置永不过期,这样就能包含保证数据的稳定性。但是需要注意,每次数据库的数据更改以后,需要更新热点缓存的数据,不然就会造成查询结果的误差。

4)缓存预热

缓存预热并不是一种问题,而是使用缓存时的一个优化方案,它可以提高前台用户的使用体验。

缓存预热指的是:在系统启动的时候,先把查询结果预存到缓存中,以便用户后面查询时可以直接从缓存中读取,节约用户的等待时间。

缓存预热的实现思路有三种:

a)把需要缓存的方法写到系统初始化方法中,这样系统在启动的时候就会自动的加载数据并缓存数据。

b)把需要缓存的方法挂载到某个页面或者后端接口上,手动触发缓存预热。

c)设置定时任务,定时自动进行缓存预热。

补充:

最后介绍一下 Redis 集群

随着业务的不断发展,单机 Redis 的性能已经不能满足需求了,此时需要将单机 Redis 扩展为多机服务,Redis 多机服务 主要包含以下3个内容:

1)Redis 主从同步

2)Redis 哨兵模式

3)Redis 集群服务(Redis 3.0新增功能)

 1)主从同步

主从同步(主从复制)是 Redis 高可用服务的基石,也是多机运行中最基础的一个。把主要存储数据的节点叫做主节点(master),把其它通过复制主节点数据的副本节点叫做从节点(从节点),如下图:

在Redis 中一个主节点可以拥有多个从节点,一个从节点也可以是其它服务器的主节点,如下图:

 

主从同步优点:

a)性能方面

有了主从同步之后,可以把查询任务分配给从服务器,用主服务器来执行写操作,这样极大的提高了程序运行的效率,把所有压力分摊给各个服务器。

b)高可用

当有了主从同步之后,当主服务器节点发生宕机之后,可以迅速的把从节点提升为主节点,为 Redis 服务器的宕机恢复节省了宝贵时间。

c)防止数据丢失

当主服务器的磁盘坏掉之后,其他从服务器还保留着相关的数据,不至于数据全部丢失。

主从同步的缺点:

当主节点崩溃之后,需要人工干预才能恢复 Redis 的正常使用。

 

2)Redis 哨兵模式

当主从服务器发生宕机的节点比较多的情况下,如果需要人工恢复,这样的难度和花费时间是很大的,因此,需要一个自动的工具——Redis Sentinel(哨兵模式)来把手动的过程变成自动的,让 Redis 拥有自动容灾恢复的能力。

使用哨兵模式可以用来监控主从服务器节点,并在主从服务器出现问题的时候,自动容灾恢复。

哨兵模式如下图:

 

3)Redis 集群服务(Redis 3.0新增功能)

Redis 集群(Redis Cluder)是 Redis 多机运行最完美的解决方案,它是 Redis 3.0之后推出的服务,它的出现可以让我们完全抛弃主从同步和哨兵模式来实现 Redis 多机运行。

Redis 集群 是无代理模式去中心化的运行模式,客户端发送的绝大多数命令会直接交给相关节点执行,这样大部分请求命令无需转发或者仅转发一次的情况下就能完成请求和响应,所以集群单个节点的性能与单机  Redis 服务器的性能是非常接近的,因此在理论情况下,当水平扩展一倍的主节点就相当于请求处理的性能也提高了一倍,所以 Redis 集群的性能是非常高的。

Redis 集群如下图:

Redis 集群可以有无数个主从节点,而 Redis 的主从同步只能有一个主节点,因此,Redis 集群拥有更强大的平行扩展能力,也就是说,当 Redis 集群拥有两个主节点时,从理论上来说,Redis 的性能比单机服务来说性能提高了 2 倍。


以上就是 Redis 的相关内容。      

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/846824.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【怎么提高性能和解决高并发】

怎么解决高并发 解决高并发的整体流程大概是&#xff1a; 先进行性能评估、再进行性能测试、然后找到程序可以承受的临界点、最后针对出问题的地方&#xff0c;进行优化。当然硬件设置对高并发的影响也很重要&#xff0c;如果达到硬件天花板&#xff0c;那么再怎么优化程序都…

如何实现网络数据传输

目录 前言 1.理解源IP地址和目的IP地址 2.理解端口号 2.1端口号与进程pid的关系 2.2源端口号和目的端口号 3.协议 3.1TCP协议 3.2认识UDP协议 4.网络字节序 5.socket编程接口 总结 前言 在上一篇文章网络框架中给大家对网络的整体进行了一个宏观的介绍&#xff0c;这…

理解递归方法

递归相关问题 树和二叉树相关的大部分问题二分查找相关问题快速排序、归并排序相关问题所有回溯的问题所有动态规划的问题 本质与特征 本质 本质就是方法的调用&#xff0c;而且是方法自己调用自己。 特征 执行时范围不断缩小&#xff0c;这样才能触底反弹终止&#xff08;结…

使用MIT Kerberos Ticket Manager在windows下浏览器访问hadoop页面

Author : Spinach | GHB Link : http://blog.csdn.net/bocai8058文章目录 前言准备配置说明安装Firefox浏览器安装MIT Kerberos Ticket Manager客户端配置krb5.ini文件配置MIT Kerberos Ticket Manager客户端配置Firefox浏览器代理参数 访问WebUI 前言 kerberos是一种计算机…

亚马逊关键词下单的作用

在亚马逊上&#xff0c;关键词对于商品的搜索和发现起着非常重要的作用。当卖家在亚马逊上发布商品时&#xff0c;他们可以使用相关的关键词来描述该商品&#xff0c;这些关键词通常是与该商品相关的词汇或短语。 关键词下单的作用如下&#xff1a; 1、商品搜索&#xff1a; 买…

vue3+antd——实现个人中心页面+同步更改头部用户信息——基础积累

之前写过一篇文章关于vue3antd的框架模板&#xff0c;链接如下&#xff1a;http://t.csdn.cn/9dZMS 首先感谢大神提供的后台管理系统的模板&#xff0c;在此基础上改动要简单很多&#xff0c;主要是自己有很多内容不太敢随意改动。。。 直接看【个人中心】页面的效果图&#…

JavaScript事件委托与事件流+牛客例题

事件流&#xff1a; 概念&#xff1a;事件完整执行过程中的流动路径 说明&#xff1a;假设页面里有个div&#xff0c;当触发事件时&#xff0c;会经历两个阶段&#xff0c;分别是捕获阶段、冒泡阶段 简单来说&#xff1a;捕获阶段是 从父到子 冒泡阶段是从子到父 注意&…

TEMU美国儿童文具亚马逊CPC测试标准

美国站儿童文具类上架跨境电商平台美国站或者出口美国需要提交CPC认证&#xff0c;才能进入美国市场&#xff0c;由CPSC 认可的实验室出具的检测报告&#xff0c;确认每件商品均已过检测&#xff0c;符合上述适用要求。但许多亚马逊卖家反映&#xff1a;在亚马逊卖的文具类产品…

哪个思维导图软件好,知道这5个就够了!

思维导图作为一种有效的组织和展示思维的工具&#xff0c;广泛应用于学习、项目管理、创意发展等领域。然而&#xff0c;手工绘制思维导图费时费力&#xff0c;限制了其在快节奏的现代生活中的应用。本文将介绍5款可以一键生成思维导图的软件&#xff0c;它将通过智能化的方式&…

Chrome 谷歌浏览器,自动填充密码,提示需要输入电脑开机密码问题

我们在使用浏览器访问各个网站时&#xff0c;经常会保存密码。在下一次访问时&#xff0c;直接使用保存的密码填充&#xff0c;简单方便。 但是突然有一天&#xff08;怀疑是谷歌浏览器更新导致的&#xff09;&#xff0c;每次使用密码填充时&#xff0c;都有如下拦截 拦截提…

前端 select 标签如何创建下拉菜单?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 代码示例⭐ 代码讲解⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏…

PyTorch中ReduceLROnPlateau的学习率调整优化器

PyTorch中ReduceLROnPlateau的学习率调整优化器 作者&#xff1a;安静到无声 个人主页 简介&#xff1a; 在深度学习中&#xff0c;学习率是一个重要的超参数&#xff0c;影响模型的收敛速度和性能。为了自动调整学习率&#xff0c;PyTorch提供了ReduceLROnPlateau优化器&…

Linux IPIP隧道连通两个局域网

拓扑结构 现有两台主机&#xff0c;它们具有两个网口分别接入到不同网络中。 主机A&#xff1a; eth0&#xff1a;处于 10.0.1.2/24 网段eth1&#xff1a; 处于192.168.1.100/24 网段 主机B&#xff1a; eth0&#xff1a;处于10.0.2.3/24 网段eth1&#xff1a; 处于192.168.2…

持续同步的实时备份软件推荐!

什么是实时备份&#xff1f; 实时备份是一种持续数据保护方法&#xff0c;通过缩短自动保存文件的时间间隔&#xff0c;可以备份每个更改的副本&#xff0c;以捕获保存数据的每个版本。 传统备份方式只能将数据还原到备份完成时的状态&#xff0c;如果在故障发生时进行恢复…

收藏!!!一起来学习IGBT基础知识。

1 IGBT是什么&#xff1f; IGBT&#xff0c;绝缘栅双极型晶体管&#xff0c;是由&#xff08;BJT&#xff09;双极型三极管和绝缘栅型场效应管&#xff08;MOS&#xff09;组成的复合全控型电压驱动式功率半导体器件, 兼有&#xff08;MOSFET&#xff09;金氧半场效晶体管的高…

init_pg_dir 的大小及作用

init_pg_dir 的大小 vmlinux.lds.S 中 在vmlinux.lds.S 中&#xff0c;有 init_pg_dir .; . INIT_DIR_SIZE; init_pg_end .;/*include/asm/kernel-pgtable.h*/ #define EARLY_ENTRIES(vstart, vend, shift) \ ((((vend) - 1) >&g…

Zebec Protocol 将进军尼泊尔市场,通过 Zebec Card 推动该地区金融平等

流支付正在成为一种全新的支付形态&#xff0c;Zebec Protocol作为流支付的主要推崇者&#xff0c;正在积极的推动该支付方案向更广泛的应用场景拓展。目前&#xff0c;Zebec Protocol成功的将流支付应用在薪酬支付领域&#xff0c;并通过收购WageLink将其纳入旗下&#xff0c;…

3.7v升压5v4A芯片用什么型号

问&#xff1a;我需要一个能够将3.7V锂电池的电压升压到5V&#xff0c;并且能够提供4A的电流输出的芯片。请问有什么推荐的型号吗&#xff1f; 答&#xff1a;小编为您推荐AH6922B芯片&#xff0c;它具备以下特点来满足您的需求&#xff1a; 1. 输入电压范围适配&#xff1a;…

SAP 计划独立需求屏幕增强(MD61/MD62/MD63)

需求&#xff1a;在计划独立需求界面新增一列自定义字段 效果如下&#xff1a; MD63&#xff1a;显示:&#xff08;注&#xff1a;客户字段在显示界面不可以编辑&#xff09; MD61&#xff1a;创建/MD62&#xff1a;修改&#xff08;注&#xff1a;创建和修改的时候客户字段可…

C语言学习笔记 vscode使用外部console-11

前言 在默认情况下&#xff0c;我们运行C语言程序都是在vscode终端的&#xff0c;在小程序运行时这个是没有问题的&#xff0c;但是当程序变得复杂它就不好用了&#xff0c;这时我们可以将这个终端设置为外部console&#xff0c;这样方便处理更多、更复杂的程序。 步骤 1.点击…