Redis学习|Redis.conf详解、Redis持久化(RDB、AOF)、Redis发布订阅

Redis.conf详解

启动的时候,就通过配置文件来启动!

配置文件 unit单位 对大小写不敏感!

包含

可以将多个配置文件合并在一起,就是好比我们学习Spring、lmprot ,include

网络

通用 GENERAL

快照

持久化 ,在规定的时间内,执行了多少次操作,则会持久化到文件.rdb  .aof
redis 是内存数据库,如果没有持久化,那么数据断电及失!

REPLICATION 复制

我们后面讲解主从复制的,时候再进行讲解

SECURITY 安全

可以在这里设置redis的密码,默认是没有密码!

限制 CLIENTS

APPEND ONLY 模式 aof配置

具体的配置,我们在 Redis持久化 中去给大家详细详解!

Redis持久化

面试和工作,持久化都是重点!
Redis 是内存数据库,如果不将内存中的数据库状态保存到磁盘,那么一旦服务器进程退出,服务器中的数据库状态也会消失。所以 Redis 提供了持久化功能!

RDB(Redis DataBase)

在指定的时间间隔内将内存中的数据集快照写入磁盘,也就是行话讲的Snapshot快照,它恢复时是将快照文件直接读到内存里。
Redis会单独创建(fork)一个子进程来进行持久化,会先将数据写入到一个临时文件中,待持久化过程都结束了,再用这个临时文件替换上次持久化好的文件,整个过程中,主进程是不进行任何操作的。这就确保了极高的性能。如果需要进行大规模数据的恢复,且对于数据恢复的完整性不是非常敏感,那RDB方式要比AOF方式更加的高效。RDB的缺点是最后一次持久化后的数据可能丢失。我们默认的就是RDB,一般情况下不需要修改这个配置!
rdb保存的文件是dump.rdb 都是在我们的配置文件中快照中进行配置的!

可以看到60秒内改变了5次key,触发了生成dump.rdb文件

此时将redis断开连接

再次重新连接上redis,看看redis是否会读取rdb文件,还能读出上次保存的数据

发现可以读出断开连接之前的数据,这就是redis的持久化操作

1、save的规则满足的情况下,会自动触发rdb规则
2、执行 flushall 命令,也会触发我们的rdb规则!

3、退出redis,也会产生 rdb 文件!

备份就自动生成一个 dump.rdb

如果恢复rdb文件!
1、只需要将rdb文件放在我们redis启动目录就可以,redis启动的时候会自动检査dump.rdb 恢复其中的数据!
2、查看需要存在的位置

几乎就他自己默认的配置就够用了,但是我们还是需要去学习!

优点:
1、适合大规模的数据恢复!
2、对数据的完整性要不高!
缺点:
1、需要一定的时间间隔进行操作!如果redis意外宕机了,这个最后一次修改数据就没有的了!
2、fork进程的时候,会占用一定的内容空间!!

AOF ( Append only File )

将我们的所有命令都记录下来,history,恢复的时候就把这个文件全部再执行一遍!

以日志的形式来记录每个写操作,将Redis执行过的所有指令记录下来(读操作不记录),只许追加文件但不可以改写文件,redis启动之初会读取该文件重新构建数据,换言之,redis重启的话就根据日志文件的内容将写指令从前到后执行一次以完成数据的恢复工作
Aof保存的是 appendonly.aof 文件

默认是不开启的,我们需要手动进行配置!我们只需要将 appendoly 改为yes就开启了 aof!

重启,redis 就可以生效了!

修改 配置文件开启aof后,可以看到目录中生成了一个aof文件,用来记录写操作

编写几个写操作

之后查看aof文件内容

发现所有的写操作都被记录其中

假设我们模拟aof文件出错,在其中加入一些乱码数据并保存

然后开启redis并连接,发现连接不上

因为如果这个 aof文件有错误,这时候 redis 是启动不起来的,我们需要修复这个aof文件redis 给我们提供了一个工具redis-check-aof --fix

可以看到这个工具就在redis的目录中,我们利用这个工具敲入下述指令来修复aof文件

修复后再次连接redis,发现连接成功,不过修复的过程中可能会丢失一些数据信息

优点:
1、每一次修改都同步,文件的完整会更加好!
2、每秒同步一次,可能会丢失一秒的数据
3、从不同步,效率最高的!
缺点:
1、相对于数据文件来说,aof远远大于rdb,修复的速度也比 rdb慢!
2、Aof 运行效率也要比rdb 慢,所以我们redis默认的配置就是rdb持久化!

扩展:
1、RDB 持久化方式能够在指定的时间间隔内对你的数据进行快照存储
2、AOF 持久化方式记录每次对服务器写的操作,当服务器重启的时候会重新执行这些命令来恢复原始的数据,AOF命令以Redis 协议追加保存每次写的操作到文件未尾,Redis还能对AOF文件进行后台重写,使得AOF文件的体积不至于过大。
3、只做缓存,如果你只希望你的数据在服务器运行的时候存在,你也可以不使用任何持久化
4、同时开启两种持久化方式
·在这种情况下,当redis重启的时候会优先载入AOF文件来恢复原始的数据,因为在通常情况下AOF文件保存的数据集要比RDB文件保存的数据集要完整。但·RDB的数据不实时,同时使用两者时服务器重启也只会找AOF文件,那要不要只使用AOF呢?作者建议不要,因为RDB更适合用于备份数据库(AOF在不断变化不好备份),快速重启,而且不会有AOF可能潜在的Bug,留着作为一个万一的手段。

5、性能建议
·因为RDB文件只用作后备用途,建议只在Slave上持久化RDB文件,而且只要15分钟备份一次就够了,只保留save 900 1这条规则。
。如果Enable AOF,好处是在最恶劣情况下也只会丢失不超过两秒数据,启动脚本较简单只load自己的AOF文件就可以了,代价一是带来了持续的IO,二是AOF rewrite 的最后将 rewrite 过程中产生的新数据写到新文件造成的阻塞几乎是不可避免的。只要硬盘许可,应该尽量减少AOFrewrite 的频率,AOF重写的基础大小默认值64M太小了,可以设到5G以上,默认超过原大小100%大小重写可以改到适当的数值,
如果不EnableAo但是的话相对要消耗也会更大点省掉一大笔

Redis发布订阅

Redis 发布订阅(pub/sub)是一种消息通信模式:发送者(pub)发送消息,订阅者(sub)接收消息.
Redis 客户端可以订阅任意数量的频道。
订阅/发布消息图:

下图展示了频道 channel1 ,以及订阅这个频道的三个客户端-- client2、 client5 和 client1 之间的关系:

当有新消息通过 PUBLISH 命令发送给频道 channel1 时,这个消息就会被发送给订阅它的三个客户端:

这些命令被广泛用于构建即时通信应用,比如网络聊天室(chatroom)和实时广播、实时提醒等

启动redis,打开一个客户端

订阅一个频道,随时监控这个频道,有消息就直接接收

再打开一个客户端

在刚才的频道发送一个消息

可以看到客户端1接收到了客户端2发送的消息

原理

Redis是使用C实现的,通过分析 Redis 源码里的 pubsub.c文件,了解发布和订阅机制的底层实现,籍此加深对 Redis 的理解,
Redis 通过 PUBLISH、SUBSCRIBE和 PSUBSCRIBE 等命令实现发布和订阅功能。
微信:
通过 SUBSCRIBE 命令订阅某频道后,redis-server 里维护了一个字典,字典的键就是一个个频道!,而字典的值则是一个链表,链表中保存了所有订阅这个 channel 的客户端。SUBSCRIBE 命令的关键,就是将客户端添加到给定 channel 的订阅链表中。通过 PUBLISH 命令向订阅者发送消息,redis-server 会使用给定的频道作为键,在它所维护的 channel字典中查找记录了订阅这个频道的所有客户端的链表,遍历这个链表,将消息发布给所有订阅者。
Pub/Sub 从字面上理解就是发布(Publish)与订阅(Subscribe),在Redis中,你可以设定对某一个kev值进行消息发布及消息订阅,当一个key值上进行了消息发布后,所有订阅它的客户端都会收到相应的消息。这一功能最明显的用法就是用作实时消息系统,比如普通的即时聊天,群聊等功能。

使用场景:
1、实时消息系统!
2、实时聊天!(频道当做聊天室,将信息回显给所有人即可!)
3、订阅,关注系统都是可以的!
稍微复杂的场景我们就会使用 消息中间件 MQ()

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值