1 在企业中,RDB的生成策略,用默认的也是可以的,AOF一定要打开,fsync,everysec即可
auto-aof-rewrite-percentage 100: 就是当前AOF大小膨胀到超过上次100%,上次的两倍
auto-aof-rewrite-min-size 64mb: 根据你的数据量来定,16mb,32mb
这两项的配置依据企业的数据量酌情配置
2 RDB非常适合做冷备,那针对RDB的数据备份方案:
(1)写crontab定时调度脚本去做数据备份
(2)每小时都copy一份rdb的备份到一个目录中,保留最近的48小时的备份
(3)每天都保留一份当日的rdb的备份,到一个目录中去,仅仅保留最近1个月的备份。
(4)每天晚上将当前服务器上所有数据的备份,发送一份到远程的云服务上去。
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%k`
rm -rf /usr/local/redis/snapshotting/$cur_date
mkdir /usr/local/redis/snapshotting/$cur_date
cp /var/redis/6379/dump.rdb /usr/local/redis/snapshotting/$cur_date
del_date=`date -d -48hour +%Y%m%d%k`
rm -rf /usr/local/redis/snapshotting/$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 /usr/local/redis/snapshotting/$cur_date
mkdir /usr/local/redis/snapshotting/$cur_date
cp /var/redis/6379/dump.rdb /usr/local/redis/snapshotting/$cur_date
del_date=`date -d -1month +%Y%m%d`
rm -rf /usr/local/redis/snapshotting/$del_date
每天一次将所有数据上传一次到远程的云服务器上去
3 当redis异常,导致数据丢失后,此时/var/redis/6379下所有的文件丢失,进行数据恢复的步骤:
(1)redis-cli SHUTDOWN 关闭redis 并及时把备份的rdb数据放入redis持久化文件存放目录 /var/redis/6379
(2)将redis配置文件中的aof机制关闭 appendonly 设为no
(3)启动redis ,此时redis将以备份的rdb文件恢复内存数据
(4)热设置aof功能打开 config set appendonly yes,此时会生成aof持久化文件,于是rdb和aof文件都做到了同步
(5)因为是热设置,aof机制没有永久生效,所以最后还要重新修改redis配置文件,将aof机制打开