news 2026/4/23 17:00:47

分享一个MySQL万能备份脚本

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
分享一个MySQL万能备份脚本

此脚本适用于 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" ]; then

read -p "请输入要备份的数据库名,多个数据库用空格分隔: " database_input

IFS=' ' read -r -a database_arr <<< "$database_input"

fi

# 输入账号和密码

read -p "请输入 MySQL 用户名: " username

read -s -p "请输入 MySQL 密码: " password

echo

# 检查文件夹是否存在,不存在则创建

if [ ! -d "$backup_dir/mysqlbak_$time" ]; then

mkdir -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"

else

for 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; do

mysqlbinlog -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 {} \;

脚本说明:

账号和密码输入:

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

数据库选择:

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

备份数据库:

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

备份 binlog 日志:

使用 mysql -e 命令获取当前的 binlog 文件列表。

遍历 binlog 文件列表,使用 mysqlbinlog 命令将每个 binlog 文件备份到指定的备份目录。

删除旧备份:

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

使用方法:

将上述脚本保存为 mybackup.sh。

给脚本添加执行权限:

chmod +x mybackup.sh

运行脚本:

./mybackup.sh

注意事项:

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:12:57

CosyVoice ONNX模型部署实战:从零到生产级的加载优化指南

CosyVoice ONNX模型部署实战&#xff1a;从零到生产级的加载优化指南 【免费下载链接】CosyVoice Multi-lingual large voice generation model, providing inference, training and deployment full-stack ability. 项目地址: https://gitcode.com/gh_mirrors/cos/CosyVoice…

作者头像 李华
网站建设 2026/4/23 13:18:26

独立式门禁读卡器与嵌入式梯控读头模块这两类产品的核心信息进行整合、对比与深化,形成一份清晰的《智能一卡通系统前端识别设备:门禁考勤机、闸机、梯控选型与部署指南》,以帮助您在不同场景下做出最优决策。

智能一卡通系统前端识别设备选型与部署指南一、 产品定位与核心差异在构建门禁、梯控、消费等一卡通系统时&#xff0c;前端识别设备是“入口”。您提供的两类产品定位截然不同&#xff0c;构成了完整的产品矩阵&#xff1a;特性维度独立式门禁/梯控读卡器(DAIC-TK-RW / DAIC-M…

作者头像 李华
网站建设 2026/4/23 11:12:11

21、网络服务与教育技术:Samba、NFS、Edubuntu与LTSP详解

网络服务与教育技术:Samba、NFS、Edubuntu与LTSP详解 1. Samba连接操作 在完成Samba配置后,可在网络中的其他主机尝试连接Samba服务器。以Ubuntu桌面为例,操作步骤如下: 1. 点击“Places”>“Connect to Server…”。 2. 从“Service type”下拉菜单中选择“Windows…

作者头像 李华
网站建设 2026/4/23 15:27:50

从可视化工作流到系统架构企业功能增强:低代码技术内核的再审

在企业数字化不断深化的背景下&#xff0c;低代码被广泛视为提升交付效率的可行方案。但其真正价值并不取决于表层的可视化界面&#xff0c;而在于可视化工作流、数据模型、逻辑引擎与系统架构能力所构成的技术内核。对这些机制的深入理解&#xff0c;有助于判断低代码在扩展性…

作者头像 李华
网站建设 2026/4/23 11:12:05

城通网盘直连下载终极方案:告别限速的完整技术指南

城通网盘直连下载终极方案&#xff1a;告别限速的完整技术指南 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 城通网盘解析工具提供了突破传统下载限制的完整解决方案&#xff0c;通过智能直连技术让用…

作者头像 李华