概述
Redis数据备份与恢复
- 企业级的持久化的配置策略
在企业中,RDB的生成策略,用默认的也差不多
save 60 10000:如果你希望尽可能确保说,RDB最多丢1分钟的数据,那么尽量就是每隔1分钟都生成一个快照,低峰期,数据量很少,也没必要
10000->生成RDB,1000->RDB,这个根据你自己的应用和业务的数据量,你自己去决定
AOF一定要打开,fsync,everysec
auto-aof-rewrite-percentage 100: 就是当前AOF大小膨胀到超过上次100%,上次的两倍
auto-aof-rewrite-min-size 64mb: 根据你的数据量来定,16mb,32mb
- 企业级的数据备份方案
RDB非常适合做冷备,每次生成之后,就不会再有修改了
数据备份方案
(1)写crontab定时调度脚本去做数据备份
(2)每小时都copy一份rdb的备份,到一个目录中去,仅仅保留最近48小时的备份
(3)每天都保留一份当日的rdb的备份,到一个目录中去,仅仅保留最近1个月的备份
(4)每次copy备份的时候,都把太旧的备份给删了
(5)每天晚上将当前服务器上所有的数据备份,发送一份到远程的云服务上去
备份脚本
每小时copy一次备份,删除48小时前的数据
crontab -e
0 * * * * sh /usr/local/redis/copy/redis_rdb_copy_hourly.sh
redis_rdb_copy_hourly.sh
#!/bin/sh
cur_date=`date +%Y%m%d%H`
rm -rf /data/soft/redis/back/$cur_date
mkdir /data/soft/redis/back/$cur_date
cp /data/soft//redis/6379/dump.rdb /data/soft/redis/back/$cur_date
del_date=`date -d -48hour +%Y%m%d%H`
rm -rf /data/soft/redis/back/$del_date
每天copy一次备份
crontab -e
0 0 * * * sh /usr/local/redis/copy/redis_rdb_copy_daily.sh
redis_rdb_copy_daily.sh
#!/bin/sh
cur_date=`date +%Y%m%d`
rm -rf /data/soft/redis/back/$cur_date
mkdir /data/soft/redis/back/$cur_date
cp /data/soft//redis/6379/dump.rdb /data/soft/redis/back/$cur_date
del_date=`date -d -1day(前一天)/month(前一月) +%Y%m%d`
rm -rf /data/soft/redis/back/$del_date
数据恢复
- 数据恢复方案
(1)如果是redis进程挂掉,那么重启redis进程即可,直接基于AOF日志文件恢复数据
不演示了,在AOF数据恢复那一块,演示了,fsync everysec,最多就丢一秒的数
(2)如果是redis进程所在机器挂掉,那么重启机器后,尝试重启redis进程,尝试直接基于AOF日志文件进行数据恢复
AOF没有破损,也是可以直接基于AOF恢复的
AOF append-only,顺序写入,如果AOF文件破损,那么用redis-check-aof fix
(3)如果redis当前最新的AOF和RDB文件出现了丢失/损坏,那么可以尝试基于该机器上当前的某个最新的RDB数据副本进行数据恢复
当前最新的AOF和RDB文件都出现了丢失/损坏到无法恢复,一般不是机器的故障,人为
(4)如果当前机器上的所有RDB文件全部损坏,那么从远程的云服务上拉取最新的RDB快照回来恢复数据
(5)如果是发现有重大的数据错误,比如某个小时上线的程序一下子将数据全部污染了,数据全错了,那么可以选择某个更早的时间点,对数据进行恢复
举个例子,12点上线了代码,发现代码有bug,导致代码生成的所有的缓存数据,写入redis,全部错了
找到一份11点的rdb的冷备,然后按照上面的步骤,去恢复到11点的数据,不就可以了吗
注意:恢复操作,如果Redis有同时开启RDB+AOF模式
-
方案一
1.先将备份的dump.rdb数据拷贝过来
2.将redis.conf配置文件的appendonly设置为no
3.启动redis 执行config set appendonly yes(热修改redis.conf配置文件)
4.关闭redis 再将redis.conf配置文件的appendonly.aof设置为yes 同时再重启Redis -
方案二
1.先将备份的dump.rdb数据拷贝过来
2.将redis.conf配置文件的appendonly设置为no
3.启动redis 执行BGREWRITEAOF命令,此时redis会将当前数据rewrite到appendonly.aof文件中
4.将redis.conf配置文件的appendonly设置为yes再重启redis
最后
以上就是哭泣云朵为你收集整理的Redis数据备份与容灾数据恢复的全部内容,希望文章能够帮你解决Redis数据备份与容灾数据恢复所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复