redis备份与恢复
1.redis的备份
redis需要远程访问 添加密码进行登录,修改主配置文件添加:
requirepass xxx
redis-cli -h 127.0.0.1 -p 6379 -a 123456 bgsave
###
-h 指定主机ip
-p 指定redis端口
-a 指定密码
bgsave:数据文件持久化到磁盘
然后到数据目录下打包备份。
tar zcf /usr/local/192.168.0.161_redis_6379.tar.gz dump.rdb
附上一个自动备份的脚本 或者写到任务计划里
#bin/bash
REDIS_DIR="/usr/local/redis/var/db/"
REDIS_PORT=`netstat -tunlp|grep redis|egrep '6379' |grep -v grep|awk '{print $4}'|awk -F: '{print $2}'`
BACKUP_DIR="/usr/local/hero_all_backup"
MYSQL_LOG="/home/msbakscript/logs/mysql.log"
HOST=$(awk -F= '/IPADDR=/ {print $2}' /etc/sysconfig/network-scripts/ifcfg-eth1)
DATE=`date +%F_%H-%M`
Hour=`date '+%H'`
pwd=IU8b2W4Nt9fIfLksLYfC
all_bak=("$HOST"_"$DATE")
increase_bak=("$HOST"_"$DATE""-increase")
DEL_DAY="7"
#################################################################
PATH="/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local/mysql/bin:/usr/local/redis/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/python/bin:/usr/local/python/sbin:/usr/
local/eventlog/bin:/usr/local/eventlog/sbin:/usr/local/syslog-ng/bin:/usr/local/syslog-ng/sbin:/root/bin"
redis_backup(){
for i in ${REDIS_PORT}
do
idt=`redis-cli -p $i -a ${pwd} info |grep role|awk -F: '{print $2}'|tr -d '\r'`
#根据redis的角色进行备份,master不开启AOF持久化,通过bgsave对RDB快照;slave开启AOF持久化,通过bgrewriteaof进行备份;
case $idt in
master)
echo "redis-cli -h 127.0.0.1 -p $i -a ${pwd} bgsave"
redis-cli -h 127.0.0.1 -p $i -a ${pwd} bgsave
;;
slvae)
echo "redis-cli -h 127.0.0.1 -p $i -a ${pwd} bgrewriteaof"
redis-cli -h 127.0.0.1 -p $i -a ${pwd} bgrewriteaof
;;
*)
exit 1
;;
esac
done
}
cp_backup(){
echo "sleep 30 waiting redis write to disk"
sleep 30
for i in ${REDIS_PORT}
do
idt=`redis-cli -p $i -a ${pwd} info |grep role|awk -F: '{print $2}'|tr -d '\r'`
#根据redis的角色进行备份,master不开启AOF持久化,通过bgsave对RDB快照;slave开启AOF持久化,通过bgrewriteaof进行备份;
case $idt in
master)
#echo cp ${REDIS_DIR}/dump.rdb ${BACKUP_DIR}/${HOST}_${i}.dump.rdb.$tt >> ${BACKUP_DIR}/redis_backup.log
#/bin/cp -f ${REDIS_DIR}/dump.rdb ${BACKUP_DIR}/${HOST}_${i}.dump.rdb.$tt
cd ${REDIS_DIR}
tar zcf ${BACKUP_DIR}/${all_bak}_${i}.tar.gz dump.rdb
echo -en "%${all_bak}_${i}.tar.gz" >>${MYSQL_LOG}
cd -
;;
slvae)
#echo cp ${REDIS_DIR}/appendonly.aof ${BACKUP_DIR}/${HOST}_${i}.appendonly.aof.$tt >> ${BACKUP_DIR}/redis_backup.log
#/bin/cp -f ${REDIS_DIR}/appendonly.aof ${BACKUP_DIR}/${HOST}_${i}.appendonly.aof.$tt
cd ${REDIS_DIR}
tar zcf ${BACKUP_DIR}/${all_bak}_${i}.tar.gz appendonly.aof
echo -en "%${all_bak}_${i}.tar.gz" >>${MYSQL_LOG}
cd -
;;
*)
exit 1
;;
esac
done
}
del_backup(){
#因所有备份都是全库备,所以按日期删除4天以前的备份数据
cd ${BACKUP_DIR}
find . \( -name "*appendonly*" -o -name "*dump*" \) -mtime +${DEL_DAY} -exec rm -f {} \;
}
#main start
mkdir -p ${BACKUP_DIR}
tt=`date +"%Y%m%d-%H%M%S"` ###按照日期时间格式进行备份
redis_backup
cp_backup
del_backup
2.redis还原
(1)停掉redis
(2)启动redis,重启是因为释放redis内存
(3)解压备份出来的redis备份
(4)拷贝覆盖到正在使用的数据目录里面
(5)再重启redis即可。
redis备份与恢复的更多相关文章
- Redis 搭建文档,备份及认证
wget http://download.redis.io/releases/redis-3.0.6.tar.gz为了方便管理,将Redis文件中的conf配置文件和常用命令移动到统一文件中[root ...
- 数据备份与恢复 半持久化 全持久化 fork aof rdb Backing up Disaster recovery 备份 容灾
Redis数据备份与恢复 - 流年晕开时光 - 博客园 https://www.cnblogs.com/deny/p/11531355.html Redis数据备份与恢复 Redis所有数据都是保存在 ...
- redis基础操作~~数据备份与恢复、数据安全、性能测试、客户端连接、分区
数据备份与恢复 数据备份redis save 命令用于创建当前数据库的备份. redis 127.0.0.1:6379> SAVE OK 该命令将在 redis 安装目录中创建dump.rdb文 ...
- Redis之数据备份与恢复
Redis 数据备份与恢复 Redis SAVE 命令用于创建当前数据库的备份. 语法 redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实例 re ...
- Redis 数据备份与恢复,安全,性能测试,客户端连接,管道技术,分区(四)
Redis 数据备份与恢复 Redis SAVE 命令用于创建当前数据库的备份. 语法 redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实例 re ...
- redis开启持久化、redis 数据备份与恢复
redis持久化介绍 https://segmentfault.com/a/1190000015897415 1. 开启aof持久化.以守护进程启动.远程访问先把配置文件拷贝一份到/etc/redi ...
- redis数据的备份与恢复
redis数据的备份与恢复 持久化分为两种方式:RDB和AOF 1.1 RDB模式 RDB方式的持久化是通过快照(snapshotting)完成的,当符合一定条件时Redis会自动将内存中的所有数据进 ...
- Redis 数据备份与恢复
Redis SAVE 命令用于创建当前数据库的备份. 语法 redis Save 命令基本语法如下: redis 127.0.0.1:6379> SAVE 实例 redis 127.0.0.1: ...
- redis数据备份与恢复
1.启动redis 进入redis目录 redis-cli 2.数据备份 redis 127.0.0.1:6379> SAVE 该命令将在 redis 备份目录中创建dump.rdb文件. 3. ...
随机推荐
- AndFix
AndFix 是阿里巴巴开源的 Android 应用热修复工具,帮助 Anroid 开发者修复应用的线上问题.Andfix 是 "Android hot-fix" 的缩写.支持 A ...
- 分析Android-Universal-Image-Loader的缓存处理机制
最近看了UIL中的缓存实现,才发现其实这个东西不难,没有太多的进程调度,没有各种内存读取控制机制.没有各种异常处理.反正UIL中不单代码写的简单,连处理都简单.但是这个类库这么好用,又有这么多人用,那 ...
- 讨论MMU
MMU是Memory Management Unit的缩写,中文名是内存管理单元,它是中央处理器(CPU)中用来管理虚拟存储器.物理存储器的控制线路,同时也负责虚拟地址映射为物理地址,以及提供硬件机制 ...
- Nginx负载均衡和反向代理的配置和优化
负载均衡 负载均衡是由多台服务器以对称的方式组成一个服务器集合,每台服务器都具有等价的地位, 反向代理 是指以代理服务器来接受internet上的请求,然后将请求转给内部的服务器 常见的负载均衡 1. ...
- 【html5】html5本地简单存储
html5本地简单存储 HTML5 提供了四种在客户端存储数据的新方法,即 localStorage .sessionStorage.globalStorage.Web Sql Database. 前 ...
- 【javascript】jQuery判断用户右击事件
jquery 判断用户是鼠标是右击还是左击, // 1 = 鼠标左键 left; 2 = 鼠标中键; 3 = 鼠标右键 $(document).mousedown(function(e) { if(3 ...
- R语言︱数据分组统计函数族——apply族用法与心得
每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 笔者寄语:apply族功能强大,实用,可以代替 ...
- Struts2(五)常量的配置
Struts2 常量大多在 默认的配置文件中已经配置好,但根据用户的需求不同,开发的要求不同,需要修改这些常量值,修改的方法就是在配置的文件对常量进行重新配置 在struts.xml 文件中使用< ...
- 常用的freemark语法(三)
一,符号的意义 1.0,单问号 ?后面要加关键字,例如:<#if object?exists>object对象不为空</#if> <#if str??>${str? ...
- activemq的案例