Redis探索之旅

这篇具有很好参考价值的文章主要介绍了Redis探索之旅。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

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

一、简介

二、Redis的安装

三、Redis的简单使用

四、Redis相关知识点

1.缓存分类

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

3.持久化

4.常见面试题


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

Redis探索之旅,redis,数据库,缓存

一、简介

先来介绍一下什么是缓存

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

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

Redis探索之旅,redis,数据库,缓存

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

Redis探索之旅,redis,数据库,缓存

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

Redis探索之旅,redis,数据库,缓存

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

 缓存优点:

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 文件

Redis探索之旅,redis,数据库,缓存

 Redis探索之旅,redis,数据库,缓存

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

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

Redis探索之旅,redis,数据库,缓存

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

Redis探索之旅,redis,数据库,缓存

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

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

 注:

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

Redis探索之旅,redis,数据库,缓存

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

Redis探索之旅,redis,数据库,缓存

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

 然后再新增一个密码:

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

requirepass 你的密码

Redis探索之旅,redis,数据库,缓存 然后再重复 上述 4)  5) 步。

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

Redis探索之旅,redis,数据库,缓存

 此时还需要输入密码:

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

Redis探索之旅,redis,数据库,缓存

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

 Redis探索之旅,redis,数据库,缓存

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

 Redis探索之旅,redis,数据库,缓存

打开后:

Redis探索之旅,redis,数据库,缓存

 Redis探索之旅,redis,数据库,缓存

 然后即可连接成功。

三、Redis的简单使用

Redis探索之旅,redis,数据库,缓存

四、Redis相关知识点

1.缓存分类

缓存大致可以分类两类:

本地缓存

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

Redis探索之旅,redis,数据库,缓存

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

分布式缓存

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

 常见的分布式缓存有: 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 值,它的使用相对比较简单,但是实际项目中应用非常广泛。
字符串的使用如下:
Redis探索之旅,redis,数据库,缓存

Hash      字典类型

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

字典类型的使用如下:

Redis探索之旅,redis,数据库,缓存

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

List         列表类型

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

列表类型的使用如下:

Redis探索之旅,redis,数据库,缓存

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

1)消息队列

2)文章列表

Set         集合类型

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

集合类型的使用如下:

Redis探索之旅,redis,数据库,缓存

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

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

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

ZSet       有序集合类型

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

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

Redis探索之旅,redis,数据库,缓存

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

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 的优点,在写入的时候,先把当前的数据 以 RDB 的形式写入文件的开头,再将后续的操作命令以 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探索之旅,redis,数据库,缓存

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

Redis探索之旅,redis,数据库,缓存

主从同步优点:

a)性能方面

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

b)高可用

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

c)防止数据丢失

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

主从同步的缺点:

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

2)Redis 哨兵模式

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

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

哨兵模式如下图:

Redis探索之旅,redis,数据库,缓存

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

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

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

Redis 集群如下图:

Redis探索之旅,redis,数据库,缓存

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


以上就是 Redis 的相关内容。      文章来源地址https://www.toymoban.com/news/detail-636200.html

到了这里,关于Redis探索之旅的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Redis如何保证缓存和数据库一致性?

    现在我们在面向增删改查开发时,数据库数据量大时或者对响应要求较快,我们就需要用到Redis来拿取数据。 Redis:是一种高性能的内存数据库,它将数据以键值对的形式存储在内存中,具有读写速度快、支持多种数据类型、原子性操作、丰富的特性等优势。 优势: 性能极高

    2024年01月16日
    浏览(70)
  • Redis---数据库和缓存如何保证一致性?

    用「读 + 写」请求的并发的场景来分析: 假如某个用户数据在缓存中不存在,请求 A 读取数据时从数据库中查询到年龄为 20,在未写入缓存中时另一个请求 B 更新数据。它更新数据库中的年龄为 21,并且清空缓存。这时请求 A 把从数据库中读到的年龄为 20 的数据写入到缓存

    2024年01月24日
    浏览(57)
  • Redis如何保障缓存与数据库的数据一致性问题?

    目录 一.最经典的数据库加缓存的双写双删模式 二. 高并发场景下的缓存+数据库双写不一致问题分析与解决方案设计 三、上面高并发的场景下,该解决方案要注意的问题 1.1 Cache Aside Pattern概念以及读写逻辑 (1)读的时候,先读缓存,缓存没有的话,那么就读数据库,然后取

    2023年04月21日
    浏览(49)
  • 数据库缓存服务——NoSQL之Redis配置与优化

    目录 一、缓存概念 1.1 系统缓存 1.2 缓存保存位置及分层结构 1.2.1 DNS缓存 1.2.2 应用层缓存 1.2.3 数据层缓存 1.2.4 硬件缓存 二、关系型数据库与非关系型数据库 2.1 关系型数据库 2.2 非关系型数据库 2.3 关系型数据库和非关系型数据库区别: 2.4 非关系型数据库产生背景 2.5 总结

    2024年02月15日
    浏览(50)
  • Redis数据库 | 发布订阅、主从复制、哨兵模式、缓存雪崩

    💗wei_shuo的个人主页 💫wei_shuo的学习社区 🌐Hello World ! Redis 发布订阅 (pub/sub) 是一种消息通信模式:发送者 (pub) 发送消息,订阅者 (sub) 接收消息 Redis 客户端可以订阅任意数量的频道 Redis主从复制是指在Redis中设置一个主节点(Master)和一个或多个从节点(Slave),

    2024年02月15日
    浏览(57)
  • Springboot+Redis:实现缓存 减少对数据库的压力

    🎉🎉欢迎光临,终于等到你啦🎉🎉 🏅我是苏泽,一位对技术充满热情的探索者和分享者。🚀🚀 🌟持续更新的专栏 Redis实战与进阶 本专栏讲解Redis从原理到实践 这是苏泽的个人主页可以看到我其他的内容哦👇👇 努力的苏泽 http://suzee.blog.csdn.net/   目录 缓存如何实现?

    2024年03月24日
    浏览(59)
  • redis面试题目-如何保证数据库与缓存的数据一致性

    原视频:https://www.bilibili.com/video/BV1Km4y1r75f?p=62vd_source=fa75329ae3880aa55609265a0e9f5d34 由于缓存和数据库是分开的,无法做到原子性的同时进行数据修改,可能出现缓存更新失败,或者数据库更新失败的情况,这时候会出现数据不一致,影响前端业务 先更新数据库,再更新缓存。缓

    2024年02月05日
    浏览(64)
  • Redis缓存MySQL数据库存储二者如何保证数据一致性

    在大型互联网应用中,由于数据库读写频繁、压力大等原因,我们通常会使用缓存来减少数据库的访问次数,提高系统的性能。而Redis作为一个高性能的内存数据库,成为了缓存的首选方案之一。但是,缓存和数据库之间存在数据一致性的问题,如何解决这个问题呢?本文将

    2023年04月19日
    浏览(52)
  • 如何保证Redis缓存和数据库的一致性问题

    熟练掌握Redis缓存技术? 那么请问Redis缓存中有几种读写策略,又是如何保证与数据库的一致性问题 今天来聊一聊常用的三种缓存读写策略 首先我们来思考一个问题 写 先更新缓存 再更新数据库 首先如果缓存更新成功但数据库更新失败,会导致数据不一致的问题 其次当请求

    2024年02月14日
    浏览(51)
  • Redis 缓存与数据库双写不一致如何解决

    Redis缓存与数据库双写不一致是一个常见的挑战,但可以通过一些方法来解决或减轻这种不一致性。以下是一些可能的解决方案: 事务处理: 在进行缓存和数据库双写时,确保它们被包含在同一事务中。这可以通过使用支持事务的数据库和Redis事务来实现。这样,要么两者同

    2024年01月21日
    浏览(53)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包