为什么要持久化
redis 一般用于缓存,基于内存,为什么要持久化?
就是因为 缓存的作用 是 为数据库减轻压力,如果宕机 会对数据库冲击,比如停电了,缓存redis没了 就完蛋了,所以要持久化。防止意外丢失缓存对数据库冲击。
持久化方式
RDB +AOF 快照 加增量
RDB快照 记录当时
AOF 记录增量数据 日志追加
Save指令 保存rdb文件 但是是单线程 阻塞形式操作,别的一些get set指令需要等待。
Bgsave 指令 单独开一个 子线程 来持久化 比较 推荐
可以配置 bgsave 触发
RDB
优势:还原很快性能好
缺点: 丢数据 数据量大 拍照耗性能 很慢
save 900 1 15分钟1次
save 300 10 5分钟10次
save 60 10000 1分钟超过10000次
AOF
默认是没有的,所以要在配置文件里面 设置
appendfsync always 只要有就搞
appendfsync everysec 1s钟的周期
appendfsync no 看心情 闲了之后追加
优势:追加很快
缺点: 还原很慢
重写:当文件太大的时候 需要重写 让文件 小一点
混合结合
aof-use-rdb-preamble yes 开启 no 关闭
优点:
混合持久化结合了RDB持久化 和 AOF 持久化的优点, 由于绝大部分都是RDB格式,加载速度快,同时结合AOF,增量的数据以AOF方式保存了,数据更少的丢失。
缺点:
兼容性差,一旦开启了混合持久化,在4.0之前版本都不识别该aof文件,同时由于前部分是RDB格式,阅读性较差