定时任务备份Docker中MySQL数据库

在个人学习和开发过程中,我们常常会遇到这样的问题:自己在服务器上搭建的数据库,由于没有专门的运维人员管理,一旦数据库崩溃或服务器到期,就会导致重要数据永久丢失。

针对这种情况,我个人采用了一种简单有效的解决方案:​​定期将数据库备份并自动推送到 Gitee(码云)等代码托管平台​​。这样即使服务器出现问题,也能从远程仓库快速恢复数据,确保数据安全。

  1. 首先编辑脚本
bash 复制代码
#!/bin/bash

container_id="mysql"  #docker中的容器的id
sync_folder="/workspace/sync"  # git文件的根目录
today=$(date +%Y%m%d) #当前日期 20240203
databses=("db1" "db1") #数据库名称
user_name="数据库用户名"
password="数据库密码"
git_repository="git@gitee.com:xxxxxx/xxxx.git" #git地址 使用的是ssh免登录形式
git_branch="test" #git的分支 

echo "######################${today}######################"

#判断是否创建了今天年月日的文件夹,如果没有创建,就创建
if [ ! -d ${sync_folder}/${today} ]; then
  mkdir -p ${sync_folder}/${today}
  echo ">>>>>>>>>>>>>创建文件夹${sync_folder}/${today}"
fi

cd ${sync_folder}/${today}

#需要导出多个数据库,使用for循环
for db in ${databses[@]}; do
  docker exec ${container_id} mysqldump -u${user_name} -p${password} ${db} > ${db}.sql
  echo ">>>>>>>>>>>>>导出数据库${db}"
  #使用zip压缩
  zip -r ${db}.zip ${db}.sql
  echo ">>>>>>>>>>>>>压缩数据库${db}"
  #删除sql文件
  rm -f ${db}.sql
  echo ">>>>>>>>>>>>>删除数据库${db}"
done

echo ">>>>>>>>>>>>>切换到${sync_folder}"
cd ${sync_folder}

#将上面的文件夹中的新数据上传到git中
echo ">>>>>>>>>>>>>添加所有变更文件到git"
git add -A
echo ">>>>>>>>>>>>>提交所有变更文件到git"
git commit -m ${today}
echo ">>>>>>>>>>>>>拉取最新代码"
git pull ${git_repository} ${git_branch}
echo ">>>>>>>>>>>>>推送代码"
git push ${git_repository} ${git_branch}
echo ">>>>>>>>>>>>>上传完成"
  1. 编写定时任务
bash 复制代码
0 0 */3 * * /workspce/sync/sync_mysql.sh >> /workspce/logs/sync_mysql.log 2>&1

本文档以 ​​Docker 环境下的 MySQL 数据库​​ 为例进行说明。

如果您使用的是其他数据库(如 PostgreSQL、Oracle 等),本方案同样适用。

如需针对特定数据库定制 Shell 备份脚本,欢迎在下方评论区留言,我们将为您提供适配方案。

相关推荐
果子⌂30 分钟前
Docker-构建镜像并实现LNMP架构
mysql·nginx·docker·容器·架构·php
无敌糖果37 分钟前
K8S数据流核心底层逻辑剖析
docker·容器·kubernetes·k8s架构·底层逻辑·k8s数据流
Trust yourself2432 小时前
使用阿里云/腾讯云安装完成mysql使用不了
mysql·阿里云·腾讯云
亲爱的非洲野猪3 小时前
Oracle与MySQL详细对比
数据库·mysql·oracle
Matrix704 小时前
Navicat实现MySQL数据传输与同步完整指南
数据库·mysql
shepherd1114 小时前
批量update实现方案全面解析与最佳实践,带你掌握到底怎么批量更新最快、性能最高
后端·mysql
程序员岳焱4 小时前
Java 与 MySQL 性能优化:MySQL连接池参数优化与性能提升
后端·mysql·性能优化
极限实验室5 小时前
一键启动:使用 start-local 脚本轻松管理 INFINI Console 与 Easysearch 本地环境
数据库·docker
没有口袋啦5 小时前
《数据库》第一次作业:MySQL数据库账户及授权
数据库·mysql
❀͜͡傀儡师5 小时前
docker 安装数据集成平台 Apache SeaTunnel 服务
docker·容器