MySQL万能备份脚本

ops/2025/2/8 5:09:06/

此脚本适用于 MySQL 各个生命周期的版本

#!/bin/bash
# mybackup.sh# 备份保留天数,建议保留三天
days=7
# 备份时间
time=$(date +%Y%m%d%H%M%S)
# 备份保存路径
backup_dir=/opt/backup
# 备份工具
tool=mysqldump
# 端口
port="3306"
# 是否采用 --all-databases 备份所有数据库,是填写 Y,否填其他
read -p "是否备份所有数据库?(Y/N): " bak_all
# 将要备份的数据库,填写将要备份的数据库
if [ "$bak_all" != "Y" ]; thenread -p "请输入要备份的数据库名,多个数据库用空格分隔: " database_inputIFS=' ' read -r -a database_arr <<< "$database_input"
fi# 输入账号和密码
read -p "请输入 MySQL 用户名: " username
read -s -p "请输入 MySQL 密码: " password
echo# 检查文件夹是否存在,不存在则创建
if [ ! -d "$backup_dir/mysqlbak_$time" ]; thenmkdir -p "$backup_dir/mysqlbak_$time"
fi# 备份数据库
if [ "$bak_all" == "Y" ]; then$tool -u"$username" -p"$password" -P"$port" --master-data=2 --single-transaction --set-gtid-purged=on --all-databases | gzip > "$backup_dir/mysqlbak_$time/mysqlbak_all_$time.sql.gz"
elsefor database in "${database_arr[@]}"; do$tool -u"$username" -p"$password" -P"$port" --master-data=2 --single-transaction --set-gtid-purged=on "$database" | gzip > "$backup_dir/mysqlbak_$time/mysqlbak_${database}_${time}.sql.gz"done
fi# 备份 binlog 日志
# 获取当前的 binlog 文件列表
binlog_files=$(mysql -u"$username" -p"$password" -P"$port" -e "SHOW BINARY LOGS;" | awk 'NR>1 {print $1}')
for binlog_file in $binlog_files; domysqlbinlog -u"$username" -p"$password" -P"$port" "$binlog_file" > "$backup_dir/mysqlbak_$time/${binlog_file}_${time}.log"
done# 删除指定天数前的备份
find "$backup_dir" -maxdepth 1 -type d -mtime +$days -name 'mysqlbak*' -exec rm -rf {} \;

脚本说明:

  1. 账号和密码输入

    • 使用 read 命令在脚本运行时提示用户输入 MySQL 用户名和密码,其中 -s 选项用于隐藏密码输入。
  2. 数据库选择

    • 询问用户是否备份所有数据库,如果选择否,则让用户输入要备份的数据库名,多个数据库名用空格分隔。
  3. 备份数据库

    • 根据用户的选择,使用 mysqldump 备份所有数据库或指定的数据库,并将备份文件压缩保存。
  4. 备份 binlog 日志

    • 使用 mysql -e 命令获取当前的 binlog 文件列表。
    • 遍历 binlog 文件列表,使用 mysqlbinlog 命令将每个 binlog 文件备份到指定的备份目录。
  5. 删除旧备份

    • 使用 find 命令删除指定天数前的备份文件夹。

使用方法:

  1. 将上述脚本保存为 mybackup.sh
  2. 给脚本添加执行权限:
chmod +x mybackup.sh
  1. 运行脚本:
./mybackup.sh

注意事项:

  • 确保用户输入的账号和密码具有足够的权限来执行备份操作。

http://www.ppmy.cn/ops/156646.html

相关文章

【4】阿里面试题整理

[1]. 介绍一下数据库死锁 数据库死锁是指两个或多个事务&#xff0c;由于互相请求对方持有的资源而造成的互相等待的状态&#xff0c;导致它们都无法继续执行。 死锁会导致事务阻塞&#xff0c;系统性能下降甚至应用崩溃。 比如&#xff1a;事务T1持有资源R1并等待R2&#x…

有关Android Studio的安装与配置并实现helloworld(有jdk的安装与配置)(保姆级教程)

目录 一.下载与配置JDK &#xff08;一&#xff09;到JDK官网下载 &#xff08;二&#xff09;有关JDK版本的选择 1.进入页面以后。往下拉&#xff0c;根据你的电脑系统来进行对应的版本进行选择&#xff1a; 2.选择完对应的版本后&#xff0c;要下载之前你需要首先接收协议…

MySQL和Redis的区别

MySQL和Redis都是流行的数据存储解决方案&#xff0c;但它们在设计、用途和特性上有显著区别。理解这些区别有助于选择合适的数据库来满足不同的应用需求。本文将详细介绍MySQL和Redis的区别&#xff0c;包括它们的架构、使用场景、性能和其他关键特性。 一、基本概述 MySQL&…

Python(Pandas)数据分析学习

1.Pandas基本构成 引入Pandas import pandas as pd 1.Series 行 对应Excel中的一行数据&#xff0c;一维数据 定义Series # 第一个参数是具体数据 # 第二个参数的对应的索引下标 # 第三个参数的行名称 data pd.Series([1,2,3,4,5], index[a,b,c,d,e], namedata) print(d…

硬件电路基础

目录 1. 电学基础 1.1 原子 1.2 电压 1.3 电流 1.电流方向&#xff1a; 正极->负极,正电荷定向移动方向为电流方向&#xff0c;与电子定向移动方向相反。 2.电荷&#xff08;这里表示负电荷&#xff09;运动方向&#xff1a; 与电流方向相反 1.4 测电压的时候 2. 地线…

docker 实战练习1

安装部署docker 和docker-compose #卸载旧版本 sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \docker-engine#安装依赖包 yum install -y yum-utils device-mapper-persistent-da…

R语言速通

1.R语言和python语言差不多&#xff0c;例如print&#xff08;&#xff09;和注释方式等&#xff0c;但是有一些细节需要注意 2.数据类型 1&#xff09;按对象类型来分是以下 6 种&#xff08;后面会详细介绍这几种类型&#xff09;&#xff1a; 向量列表矩阵数组因子数据框…

IM 即时通讯系统-45-merua0oo0 IM 分布式聊天系统

IM 开源系列 IM 即时通讯系统-41-开源 野火IM 专注于即时通讯实时音视频技术&#xff0c;提供优质可控的IMRTC能力 IM 即时通讯系统-42-基于netty实现的IM服务端,提供客户端jar包,可集成自己的登录系统 IM 即时通讯系统-43-简单的仿QQ聊天安卓APP IM 即时通讯系统-44-仿QQ即…