redis数据备份shell脚本(为了可以回滚到当天版本)

  • 这个脚本是我会放2个版本,第一个版本是带有中文详细注释的。第二个版本是无注释清爽版。
  • 这个脚本的作用是每天备份一下/vdb/redis/dump_6379.rdb这个文件。
  • dump_6379.rdb这个文件是Redis 数据库服务器生成的 RDB(Redis Database)持久化文件。每天的这个dump_6379.rdb中的内容都是不一样的,这样我按天来备份这个dump_6379.rdb文件,并且放在以当天日期为名字的文件夹中,这样可以方便后面加载这个 RDB 文件来恢复指定哪天的数据状态;
  • 举个例子,我在2024年10月9日备份了/vdb/redis/dump_6379.rdb这个文件,并把备份文件压缩后放在/vdb/redis_dump中,这样的话,假如我2024年10月11号想看10月9日的redis数据的时候,就可以用他来恢复10月9日当天的redis数据了。
  • 解释完成,下面请看bash脚本
bash 复制代码
#!/bin/bash
#para
 给day赋值为当天的日期,假设今天是2024年10月1日,那么day=20241001
day=`date "+%Y%m%d"`   

给day_del赋值为七天前的日期,假设今天是2024年10月1日,那么day_del=20240924
day_del=`date -d "7 day ago" +%Y%m%d`  

在/vdb/redis中查找"dump.*.rdb"这个字眼的东西。如果存在/vdb/redis/dump_6379.rdb这个文件,那么file=/vdb/redis/dump_6379.rdb
files=`find /vdb/redis|grep dump.*.rdb`

/vdb/redis_dump作为备份的文件夹
bakdir="/vdb/redis_dump"

假日今天是2024年10月1日,那么运行了这个脚本到这一行,就会创建/vdb/redis_dump/20241001这个文件夹
mkdir -p $bakdir/$day

一般来说dump.*.rdb这样的文件可能会有多个,也可能只有一个,看你们是怎么部署的了,主从部署的话只有一个。
for file in $files
do
输出这样一句话"2024年10月1日 COPY /vdb/redis/dump_6379.rdb TO /vdb/redis_dump/20241001",也就是说
echo `date`  COPY $file TO $bakdir/$day

把/vdb/redis/dump_6379.rdb 复制到这个文件夹下面/vdb/redis_dump/20241001,并将其以gz格式来压缩
cp  $file $bakdir/$day && gzip $bakdir/$day/*

如果上一个命令的退出状态码(存储在 $? 变量中)等于 0 ,则输出 "$file bak Successful" ,反之则输出"file bak EEOR",
就是上一句代码"cp  $file $bakdir/$day && gzip $bakdir/$day/*"执行成功了,他的退出状态码才会是0的
if [ $? -eq 0 ];then
echo "$file bak Successful"
else
echo "$file bak EEOR"
exit
fi
done

#del dump
打开/vdb/redis_dump这个路径
cd $bakdir

在当前/vdb/redis_dump这个路径下,搜索以20开头,并且第三第四个元素是0-9中的数字,然后让bak这个参数在其中for循环。
for bak in `ls | grep ^20[0-9][0-9]`
do

首先echo $bak 输出变量 $bak 的值。
然后,cut -c 1-10 从输出的结果中截取前 10 个字符。
最后,sed 's/-//g' 把截取到的这 10 个字符中的 - 全部删除
最后拿这个结果和day_del这个参数进行比较,-le 是 "小于或等于" 的比较运算符
假设今天是2024年10月1日,那么day_del就是20240924,
当bak循环到20241001,那么day_del就是20240924,也就是20241001和20240924来比较大小
20241001没有小于等于20240924,所以不执行后面的代码。
然后当bak循环到20240923,20240923小于等于20240924,所以要执行后面的代码
也就是迭代删除掉20240923这个文件夹中的内容并输出"20240923 need to delete"
        if [ `echo $bak | cut -c 1-10 | sed 's/-//g'` -le $day_del ]
        then
                echo "$bak need to delete"
                rm -rf $bak

如果上一条指令执行成功了,那么上调指令的退出状态码(存储在 $? 变量中)等于 0 ,if判断语句逻辑为
 $? -ne 0 意思是退出状态码$?不等于0
                if [ $? -ne 0 ]
                then
                        echo "ERROR when delete the bak: $bak !!"
                else
                        echo "Delete $bak Successful"
                fi
        fi
done

以下是没有注释的清爽版

bash 复制代码
#!/bin/bash

#para
day=`date "+%Y%m%d"`
day_del=`date -d "7 day ago" +%Y%m%d`
files=`find /vdb/redis|grep dump.*.rdb`
bakdir="/vdb/redis_dump"


mkdir -p $bakdir/$day

for file in $files
do
echo `date`  COPY $file TO $bakdir/$day
cp  $file $bakdir/$day && gzip $bakdir/$day/*
if [ $? -eq 0 ];then
echo "$file bak Successful"
else
echo "$file bak EEOR"
exit
fi
done

#del dump
cd $bakdir
for bak in `ls | grep ^20[0-9][0-9]`
do
        if [ `echo $bak | cut -c 1-10 | sed 's/-//g'` -le $day_del ]
        then
                echo "$bak need to delete"
                rm -rf $bak
                if [ $? -ne 0 ]
                then
                        echo "ERROR when delete the bak: $bak !!"
                else
                        echo "Delete $bak Successful"
                fi
        fi
done
相关推荐
F_D_Z12 分钟前
【SQL】Windows MySQL 服务查询&启动&停止&自启动(保姆级)
数据库·sql·mysql
momo小菜pa18 分钟前
【MySQL 08】复合查询
数据库·mysql
小安运维日记26 分钟前
Linux云计算 |【第四阶段】RDBMS2-DAY3
linux·运维·服务器·数据库·mysql·云计算
睿思达DBA_WGX1 小时前
MySQL 实验 7:索引的操作
数据库·mysql
胖头鱼的鱼缸(尹海文)2 小时前
数据库管理-第251期 一个十年+的PC DIY爱好者看NUMA(20241011)
数据库
Data 3172 小时前
Hive数仓操作(十二)
大数据·数据库·数据仓库·hive·hadoop
一只安3 小时前
高效查找服务器漏洞
数据库·网络安全·安全威胁分析
小刘要进步3 小时前
JDBC编程
数据库
golitter.3 小时前
MySql - 数据库操作
数据库·mysql·oracle
消失在人海中3 小时前
mysql 和oracle 数据库的区别
数据库·mysql·oracle