MySQL、MariaDB、OceanBase远程异地定时备份脚本

问题背景

公司需要在异地机房远程备份数据库,以防止数据丢失,同时要支持MySQL、MariaDB和OceanBase。由于MariaDB和OceanBase支持MySQL语法,所以可以直接用MySQL Client进行备份。

安装MySQL客户端

bash 复制代码
yum install mysql

编写脚本

编写/backup/backup.sh,它的作用是执行备份到sql文件,并自动压缩成tar.gz压缩包,再删除30天前的压缩包

bash 复制代码
#!/bin/bash

# 检查参数个数
if [ "$#" -lt 3 ]; then
    echo "Usage: $0 <remote_user>@<server>:<port> -p <password> -d <database_name>"
    exit 1
fi

# 解析参数
REMOTE_INFO="$1"
REMOTE_DB_PASSWORD=""
REMOTE_DB_NAME=""

# 从第一个参数中提取用户名、主机和端口
IFS='@' read -ra ADDR <<< "$REMOTE_INFO"
IFS=':' read -ra USR <<< "${ADDR[1]}"
REMOTE_DB_USER=${ADDR[0]}
REMOTE_DB_HOST=${USR[0]}
REMOTE_DB_PORT=${USR[1]}

# 从第二个参数中提取密码
for arg in "$@"; do
    case $arg in
        -p) shift; REMOTE_DB_PASSWORD="$1";;
        -d) shift; REMOTE_DB_NAME="$1";;
        *) shift;;
    esac
done
echo ----------------开始备份---------------------
echo REMOTE_DB_USER=$REMOTE_DB_USER
echo REMOTE_DB_HOST=$REMOTE_DB_HOST
echo REMOTE_DB_PORT=$REMOTE_DB_PORT
echo REMOTE_DB_PASSWORD=$REMOTE_DB_PASSWORD
echo REMOTE_DB_NAME=$REMOTE_DB_NAME

BACKUP_PATH="/backup/${REMOTE_DB_HOST}_${REMOTE_DB_PORT}_${REMOTE_DB_NAME}"
DATE=$(date +%Y%m%d_%H%M%S)
BACKUP_FILE="$BACKUP_PATH/$REMOTE_DB_NAME-$DATE.sql"
TAR_FILE="$BACKUP_FILE.tar.gz"
DAYS_TO_KEEP=30

# 创建备份目录,如果不存在的话
mkdir -p $BACKUP_PATH

# 远程备份命令,包含端口号
mysqldump -h $REMOTE_DB_HOST -u $REMOTE_DB_USER -p$REMOTE_DB_PASSWORD -P $REMOTE_DB_PORT $REMOTE_DB_NAME > $BACKUP_FILE

# 检查备份是否成功
if [ $? -eq 0 ]; then
    echo "备份成功: $BACKUP_FILE"

    # 压缩备份文件
    cd $BACKUP_PATH
    tar czf $TAR_FILE $REMOTE_DB_NAME-$DATE.sql
    if [ $? -eq 0 ]; then
        echo "压缩成功: $TAR_FILE"
    else
        echo "压缩失败"
    fi

    # 删除原.sql文件
    rm -f $BACKUP_FILE
    if [ $? -eq 0 ]; then
        echo "删除备份文件: $BACKUP_FILE"
    else
        echo "删除备份文件失败: $BACKUP_FILE"
    fi

    # 删除旧备份文件
    find $BACKUP_PATH -type f -name "*.tar.gz" -mtime +$DAYS_TO_KEEP -exec rm -f {} \;
    if [ $? -eq 0 ]; then
        echo "已自动清理 $DAYS_TO_KEEP 天前的压缩包"
    else
        echo "清理压缩包失败"
    fi
else
    echo "备份失败"
fi

设置定时任务

bash 复制代码
crontab -e

和vi的使用方法一样,在里面写上如下的信息即可,假设在192.168.1.10这台服务器上有个MySQL开了3306端口,并且用户名为root,密码为MyPass@w0rd,数据库为test_db,每天晚上0点准时备份,则定时任务这么写:

bash 复制代码
0 0 * * * /backup/backup.sh root@192.168.1.10:3306 -p MyPass@w0rd -d test_db >> /backup/system.log

如果要备份多个库直接写多行即可:

bash 复制代码
0 0 * * * /backup/backup.sh root@192.168.1.10:3306 -p MyPass@w0rd -d test_db >> /backup/system.log
5 0 * * * /backup/backup.sh root@192.168.1.11:3306 -p !@3QWEasd -d test_db2 >> /backup/system.log

这样系统就会在0点备份test_db库,在0点5分备份test_db2库,最后备份出来的压缩包会放在\backup\192.168.1.10_3306_test_db\\backup\192.168.1.11_3306_test_db2\下面

已知的其他问题

mysqldump不支持复杂的视图和函数备份,一般这俩也不会经常动,所以建议单独备份一下。

相关推荐
invicinble6 小时前
对于Mysql深入理解
数据库·mysql
霖霖总总8 小时前
[小技巧56]深入理解 MySQL 聚簇索引与非聚簇索引:原理、差异与实践
数据库·mysql
伐尘8 小时前
【MySQL】间隙锁 与 排他锁 的区别
数据库·mysql
快乐非自愿10 小时前
【面试题】MySQL 的索引类型有哪些?
数据库·mysql·面试
霖霖总总10 小时前
[小技巧55]深入解析数据库日志机制:逻辑日志、物理日志与物理逻辑日志在 MySQL InnoDB 中的实现
数据库·mysql
OceanBase数据库官方博客10 小时前
主流关系型数据库系统缺陷实证研究——OceanBase 校企联合研究
数据库·oceanbase·分布式数据库
OceanBase数据库官方博客12 小时前
客户案例|美的以OceanBase为基构建云中立数字化基座破局多云孤岛
数据库·oceanbase·分布式数据库
OceanBase数据库官方博客12 小时前
基于分层协作多智能体的数据库参数调优——OceanBase 校企研究
数据库·oceanbase·分布式数据库
luoluoal13 小时前
基于python的人脸识别的酒店客房入侵检测系统(源码+文档)
python·mysql·django·毕业设计·源码
uoKent13 小时前
MySQL示例数据库
数据库·mysql