Redis-高效的NoSQL数据库之Redis持久化策略
前言
Redis不仅仅是一个内存型数据库,还具备持久化能力
一、RDB
rdb模式是默认模式,是在指定的时间间隔内生成数据快照(snapshot),默认保存到dump.rdb文件中。当redis重启后会自动加载dump.rdb文件中内容到内存中。
用户可以使用SAVE(同步)或BGSAVE(异步)手动保存数据。
设置服务器配置的save选项,让服务器每隔一段时间自动执行一次BGSAVE命令,可以通过save选项设置多个保存条件,但只要其中任意一个条件被满足,服务器就会执行BGSAVE命令。
例如:
save 800 1
save 500 10
save 60 1000
那么只要满足以上三个条件中的任意一个,BGSAVE命令就会被执行 。
服务器在800秒之内,对数据库进行了至少1次修改。
服务器在500秒之内,对数据库进行了至少10次修改 。
服务器在60秒之内,对数据库进行了至少1000次修改。
1.优点
- rdb文件是一个紧凑文件,直接使用rdb文件就可以还原数据。
- 数据保存会由一个子进程进行保存,不影响父进程。
- 恢复数据的效率要高于aof
2.缺点
- 每次保存点之间会导致redis不可意料的关闭,可能会丢失数据。
- 由于每次保存数据都需要fork()子进程,在数据量比较大时可能会比较耗费性能。
二、AOF
AOF默认是关闭的,需要在配置文件中开启AOF。Redis支持AOF和RDB同时生效,如果同时存在,AOF优先级高于RDB(Redis重新启动时会使用AOF进行数据恢复)
它会监听执行的命令,如果发现执行了修改数据的操作,同时直接同步到数据库文件中。
1.优点
- 相对RDB数据更加安全。
2.缺点
- 相同数据集AOF要大于RDB。
- 相对RDB可能会慢一些。
2.开启办法
修改redis.conf中
# 默认no
appendonly yes
# aof文件名
appendfilename "appendonly.aof"