一、全量同步(RDB)与增量同步(AOF)的区别

全量同步:每天定时(避开高峰期)或者采用一个周期实现将数据拷贝到一个地方(RDB)

增量同步:采用对行为的操作实现对数据的同步(AOF)

二、RDB与AOF实现持久化的区别

Redis提供了两种持久化的机制,分别为RDB、AOF实现,RDB采用定时(全量)持久化机制,但是服务器因为某种原因宕机后可能数据会丢失,AOF是基于数据日志操作实现的持久化,所以AOF采用增量同步的方案。

Redis已经帮助我默认开启了rdb存储。

三、Redis的RDB和AOF同步配置

RDB

redis默认采用RDB方式实现数据的持久化,以快照的形式将数据持久化到磁盘的是一个二进制文件dump.rdb。我们可以通过修改redis.conf配置文件来控制RDB快照的频率。

#在900秒(15分钟)之后,如果至少有1个key发生变化,则dump内存快照。
save 900 1
#在300秒(5分钟)之后,如果至少有10个key发生变化,则dump内存快照。
save 300 10
#在60秒(1分钟)之后,如果至少有10000个key发生变化,则dump内存快照。
save 60 10000

在这里插入图片描述

AOF

在redis的配置文件中存在三种AOF同步方式,分别是:

appendfsync always     #每次有数据修改发生时都会写入AOF文件,能够保证数据不丢失,但是效率非常低。 
appendfsync everysec  #每秒钟同步一次,可能会丢失1s内的数据,但是效率非常高。
appendfsync no          #从不同步。高效但是数据不会被持久化。
直接修改redis.conf中 appendonly yes

在这里插入图片描述
AOF是以执行命令的形式实现同步。


本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!

Redis实现分布式锁 上一篇