月光代碼園

記錄、分享、交流

导航

Redis学习笔记#7:持久化实战篇

RDB

安装redis后默认开启RDB,配置文件属性save在redis.conf中配置:

查看dump文件位置

config get dir

RDB快照测试

存入3条数据

 

查看日志

存入3条日志满足了“save 60 2”这个条件(60秒内更新了2条数据),所以触发了快照保存

RDB丢失数据测试

新增3条数据,然后kill redis进程

重新启动redis,这时候redis会从dump文件恢复数据,可以看到有数据丢失

手动保存

bgsave fork出一个子进程,在子进程进行保存操作,主进程不受影响

save 会阻塞redis主进程

 

AOF

开启AOF,设置同步方式

编辑redis.conf

appendonly yes
appendfsync always  # 每次有数据修改发生时都会写入AOF文件(安全但是费时)。
appendfsync everysec  # 每秒钟同步一次,该策略为AOF的缺省策略。
appendfsync no  # 从不同步。高效但是数据不会被持久化。
appendfilename "appendonly.aof"

启动redis-cli,输入set aoftest 1604

查看appendonly.aof文件内容如下:

AOF重写测试

相关配置

# 重写AOF时,是否继续写AOF文件
no-appendfsync-on-rewrite no

# 自动重写AOF文件的条件
auto-aof-rewrite-percentage 100 #百分比
auto-aof-rewrite-min-size 64mb #大小

# 是否忽略最后一条可能存在问题的指令
aof-load-truncated yes

执行set aoftest 1611,查看aof文件

执行bgrewriteaof

查看aof文件

重启redis,查看redis日志

 

AOF文件损坏修复

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

 

 

 

 

 

 

 

 

posted on 2019-08-12 17:01  bangdikka  阅读(308)  评论(0编辑  收藏  举报