【Redis】3.持久化rdb和aof

持久化是什么

rdb(Redis DataBase):存储结果,保存的是dump.rdb文件
aof:(Append Only File)存储命令
两者同时存在启动的时候先aof
【Redis】3.持久化rdb和aof_第1张图片

RDB

缺陷:丢失最后一次保存的数据
(1)修改dump.rdb
rdb(Redis DataBase):存储结果,保存的是dump.rdb文件
靠的也是dump.rdb来恢复数据
通过修改redis.conf 文件中的快照的save 设置多少秒内修改次数保存rdb文件
【Redis】3.持久化rdb和aof_第2张图片
【Redis】3.持久化rdb和aof_第3张图片

(2)存入数据后删除dump.rdb

根据自己设置的多少秒内changes了多少次保存rdb,达到那个次数后退出
删除rdb文件

cp dump.rdb dumpbk.rdb 
rm -f dump.rdb   

在这里插入图片描述
(3)再次登陆查看

/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf 
/usr/local/redis/bin/redis-cli -h 192.168.0.52 -p 6380
keys *

为null
(4)复制dumpbk.rdb

cp dumpbk.rdb dump.rdb 
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis.conf 
/usr/local/redis/bin/redis-cli -h 192.168.0.52 -p 6380
keys *

【Redis】3.持久化rdb和aof_第4张图片
(5) 没达到changes次数通过save命令快速备份

save

【Redis】3.持久化rdb和aof_第5张图片
(6)其他配置
【Redis】3.持久化rdb和aof_第6张图片
【Redis】3.持久化rdb和aof_第7张图片

AOF

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

vi redis.conf 

找到 APPEND ONLY MODE
【Redis】3.持久化rdb和aof_第8张图片
(1)复制redis.conf

cp redis.conf redis_aof.conf

【Redis】3.持久化rdb和aof_第9张图片
(2)启动Redis
/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis_aof.conf
/usr/local/redis/bin/redis-cli -h 192.168.0.52 -p 6380
【Redis】3.持久化rdb和aof_第10张图片
【Redis】3.持久化rdb和aof_第11张图片
(3)把生成的rdb文件删除
【Redis】3.持久化rdb和aof_第12张图片
(4)再次登陆却显示为empty
【Redis】3.持久化rdb和aof_第13张图片
原因是 appendonly.aof 文件忠诚的把flushall 命令也记录了,
通过dd删除 :wq保存
【Redis】3.持久化rdb和aof_第14张图片
(5)再次启动

/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis_aof.conf 
/usr/local/redis/bin/redis-cli -h 192.168.0.52 -p 6380

【Redis】3.持久化rdb和aof_第15张图片

AOF文件appednonly.aof出错

1.把appendonly.aof胡乱修改保存
【Redis】3.持久化rdb和aof_第16张图片
2.再次启动redis 报错
【Redis】3.持久化rdb和aof_第17张图片
3.使用redis-check-aof --fix 修复

redis-check-aof --fix ../etc/appendonly.aof

【Redis】3.持久化rdb和aof_第18张图片
(4)再次启动

/usr/local/redis/bin/redis-server /usr/local/redis/etc/redis_aof.conf 
/usr/local/redis/bin/redis-cli -h 192.168.0.52 -p 6380

【Redis】3.持久化rdb和aof_第19张图片

AOF Rewrite

【Redis】3.持久化rdb和aof_第20张图片
aof采用文件追加,会使文件越来越大,文件大小超过设定阈(yu)值
重写原理:
AOF文件持续增长而过大时,会fork出一条新进程来将文件重写(也是先写临时文件最后再rename),
遍历新进程的内存中数据,每条记录有一条的Set语句。重写aof文件的操作,并没有读取旧的aof文件,
而是将整个内存中的数据库内容用命令的方式重写了一个新的aof文件,这点和快照有点类似

总结

【Redis】3.持久化rdb和aof_第21张图片
【Redis】3.持久化rdb和aof_第22张图片

你可能感兴趣的:(【Redis】)