1. RDB
Redis DataBase
1.1 自动备份
redis是内存数据库,当我们每次用完redis,关闭linux时,按道理来说,内存释放,redis中的数据也会随之消失。为什么我们再次启动redis的时候,昨天的数据还在,并没有消失呢?
接下来我们就来全方位的认识 自动备份机制
vim redis.conf
/SNAP # 搜索
save 900 1 #900秒内,至少变更1次,才会自动备份
save 300 10 #300秒内,至少变更10次,才会自动备份
save 60 10000 # 60秒内,至少变更10000次,才会自动备份
注意:
如果你只是使用Redis的缓存功能,而不需要持久化,那么你就可以注释掉所有的save行停用该功能。然后可以直接一个空字符串来实现停用:save ""
- 使用shutdown模拟关机,关机之前和关机之后,对比dump.rdb文件的时间
注意:
当我们使用shutdown命令,redis会自动将数据库备份。所以,dump.rdb文件创建时间会更新。 - 开机启动redis,然后在300秒内保存10条数据,再查看dump.rdb文件的更新时间(开两个终端窗口,方便查看)
- 300秒内保存10条数据这一动作触发了备份指令,所以目前的dump.rdb文件中保存了10条数据,将dump.rdb拷贝一份dump10.rdb,此时两个文件中都保存10条数据
- 既然有数据已经备份了,那我们就肆无忌惮的通过
flushall
命令将数据全部删除,再次shutdown关机 - 再次启动redis,发现数据真的消失了,并没有按照我们所想的将dump.rdb文件中的内容恢复到redis中。为什么?
因为,当我们保存10条以上的数据时,数据备份起来了;然后删除数据库,备份文件中的数据,也没问题;
但是,问题出在shutdown上,这个命令一旦执行,就会立刻备份,将删除之后的空数据库生成备份文件,
将之前装10条数据的备份文件覆盖掉了,所以自动恢复失败。怎么解决这个问题呢?要将备份文件再备份。
我们前面已经备份了一个dump10.rdb的文件。
1.2 手动备份
之前自动备份,必须更改好多数据,例如上边,我们改变了十多条数据,才会自动备份;现在,我只保存一条数据,就想立刻备份,应该怎么做?每次操作完成,执行命令 save 就会立刻备份
1.3 与RDB相关的配置
stop-writes-on-bgsave-error
:进水口和出水口,出水口发生故障与否
rdbcompression
:对于存储到磁盘中的快照,是否启动LZF压缩算法,一般都会启动,因为这点性能,多买一台电脑,完全搞定N个来回了。
rdbchecksum
:在存储快照后,是否启动CRC64算法进行数据校验;
dbfilename
:快照备份文件名字dir
:快照备份文件保存的目录,默认为当前目录
优势and劣势
- 优势:适合大规模数据恢复,对数据完整性和一致行要求不高;
- 劣势:一定间隔备份一次,意外down掉,就失去最后一次快照的所有修改
2. AOF
Append Only File
2.1 开启AOF
appendonly yes
appendfilename "appendonly.aof"
注意:
编辑这个文件,最后要 :wq! 强制执行
redis-server /opt/redis-5.0.4/redis.conf
2.2 共存?谁优先?
我们查看redis.conf文件,AOF和RDB两种备份策略可以同时开启,那系统会怎样选择?
- 编辑appendonly.aof,在文件中随便乱写一串代码,保存退出
- 启动redis ,结果失败,所以是AOF优先载入来恢复原始数据!因为AOF比RDB数据保存的完整性更高!
- 修复AOF文件,通过下面命令杀光不符合redis语法规范的代码
reids-check-aof --fix appendonly.aof
2.3 与AOF相关的配置
appendonly
:开启aof模式 appendfilename:aof的文件名字,最好别改!appendfsync
:追写策略
no-appendfsync-on-rewrite
:重写时是否运用Appendfsync追写策略;用默认no即可,保证数据安全性。
- AOF采用文件追加的方式,文件会越来越大,为了解决这个问题,增加了重写机制,redis会自动记录上一次AOF文件的大小,当AOF文件大小达到预先设定的大小时,redis就会启动 AOF文件进行内容压缩,只保留可以恢复数据的最小指令集合
auto-aof-rewrite-percentage
:如果AOF文件大小已经超过原来的100%,也就是一倍,才重写压缩auto-aof-rewrite-min-size
:如果AOF文件已经超过了64mb,才重写压缩
3 总结(如何选择?)
- RDB:只用作后备用途,建议15分钟备份一次就好
- AOF:
- 在最恶劣的情况下,也只丢失不超过2秒的数据,数据完整性比较高,但代价太大,会带来持续的IO
- 对硬盘的大小要求也高,默认64mb太小了,企业级最少都是5G以上;
- 后面要学习的master/slave才是新浪微博的选择!!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。