Redis数据备份方案

###只是为了查询方便,方法为借鉴网络的文章,文章贴在这里供参考:
http://blog.csdn.net/subuser/article/details/8157178

Redis提供了两种持久化选项,分别是RDB和AOF。
默认状况下60秒刷新到disk一次[save 60 10000 当有1w条keys数据被改变时],Redis的数据集保存在叫dump.rdb一个二进制文件,这种策略被称为快照。
也能够手动调用Save或BGSAVE命令的:
/usr/local/bin/redis-cli -h 127.0.0.1 -p 6379 -a pwd bgsave
快照易恢复,文件也小,可是若是遇到宕机等状况的时候快照的数据可能会不完整。此时可能须要启用另外一种持久化方式AOF,在配置文件中打开[appendonly yes]。

AOF刷新日志到disk的规则:
appendfsync always #always 表示每次有写操做都进行同步,很是慢,很是安全。
appendfsync everysec #everysec表示对写操做进行累积,每秒同步一次
官方的建议的everysec,安全,就是速度不够快,若是是机器出现问题可能会丢失1秒的数据。
也能够手动执行bgrewriteaof进行AOF备份:
/usr/local/bin/redis-cli -h 127.0.0.1 -p 6379 -a pwd bgrewriteaof

咱们如今的作法是一主(Master)多从(Slave),主库不开启AOF持久化,只是天天备份一下RDB[官方给的建议是每小时备份RDB文件,看你的策略了],而在从库上开启AOF备份;

当redis服务器挂掉时,重启时将按照如下优先级恢复数据到内存:
若是只配置AOF,重启时加载AOF文件恢复数据;
若是同时 配置了RBD和AOF,启动是只加载AOF文件恢复数据;
若是只配置RBD,启动是讲加载dump文件恢复数据。
恢复时须要注意,要是主库挂了不能直接重启主库,不然会直接覆盖掉从库的AOF文件,必定要确保要恢复的文件都正确才能启动,不然会冲掉原来的文件。

根据以上修改redis的备份脚本 #!/bin/sh # for i in `netstat -nlpt|grep redis|awk -F: '{print $2}'|awk '{print $1}'` do         idt=`redis-cli -p $i info |grep role|awk -F: '{print $2}'|tr -d '\r'`                                     ### tr -d ‘\r’去掉换行符   #根据redis的角色进行备份,master不开启AOF持久化,经过bgsave对RDB快照;slave开启AOF持久化,经过bgrewriteaof进行备份;         case $idt in         master)                         redis-cli -h 127.0.0.1 -p $i -a pwd bgsave                         ;;         slvae)                         redis-cli -h 127.0.0.1 -p $i -a pwd bgrewriteaof                         ;;         *)                         exit 1                         ;;         esac done sleep 600 tt=`date +"%Y%m%d-%H%M%S"`    ###按照日期时间格式进行备份 echo     "--------------------------$tt------------------------------" >>/data/backup/redis_backup.log    ##日志记录备份详情 #将备份的AOF或者RDB拷贝到备份目录下 for i in `find /data/ -name "*.aof"` do                 echo cp $i /data/backup/`basename $i`.$tt >> /data/backup/redis_backup.log                 /bin/cp -f $i /data/backup/`basename $i`.$tt done for i in `find /data/ -name "dump*.rdb"` do                 echo cp $i /data/backup/`basename $i`.$tt >>/data/backup/redis_backup.log                 /bin/cp -f $i /data/backup/`basename $i`.$tt done #因全部备份都是全库备,因此按日期删除4天之前的备份数据 cd /data/backup find . \( -name "appendonly*" -o -name "dump*" \)    -mtime +4 -exec    rm -f {} \;    
相关文章
相关标签/搜索