当前位置: 首页 > article >正文

学习笔记080——如何备份服务器中Docker创建的MySQL数据库数据?

背景:
需要定期备份Ubuntu服务器中,MySQL数据库的数据。
但是我服务器中的MySQL不是传统的安装的,而是在Docker中的。

解决:
通过编写sh脚本,通过系统中的crontab来定时执;实现定时备份。

脚本内容:

#用户名
mysql_user="root"
#密码
mysql_password="ys_nj_sst!"
#ip
mysql_host="192.168.2.200"
#端口号 
mysql_port="33064"
#将要备份的数据库
database_name="sx_lt_wmg"
#docker中mysql的容器名
mysql_container_id="485d9030fbf4"
#编码格式
mysql_charset="utf8"
#保存备份文件最多个数
count=3
#备份保存路径
backup_path=/home/ys/bakup
#日期
date_time=`date +%Y-%m-%d-%H-%M`

#如果文件夹不存在则创建
if [ ! -d $backup_path ]; 
then     
    mkdir -p $backup_path; 
fi
#查看MySQL是否在运行
mysql_ps=`ps -ef |grep mysql |wc -l` 
echo "查看MySQL是否在运行:$mysql_ps" >> $backup_path/dump.log
mysql_listen=`netstat -an |grep LISTEN |grep $mysql_port|wc -l`
if [ [$mysql_ps == 0] -o [$mysql_listen == 0] ]; then
        echo "ERROR:MySQL is not running! backup stop!" >> $backup_path/dump.log
        exit
else
        echo "Welcome to use MySQL backup tools!" >> $backup_path/dump.log

echo "MySQL connect ok! Please wait......" >> $backup_path/dump.log
fi
#开始备份
echo "开始备份..." >> $backup_path/dump.log
docker exec $mysql_container_id /usr/bin/mysqldump -h$mysql_host -P$mysql_port -u$mysql_user -p$mysql_password $database_name --default-character-set=$mysql_charset > $backup_path/$database_name-$date_time.sql


#开始压缩
cd $backup_path
tar -zcvf $database_name-$date_time.tar.gz $database_name-$date_time.sql
#更新备份日志
echo "压缩原文件 create $backup_path/$database_name-$date_time.tar.gz" >> $backup_path/dump.log

#删除源文件
rm -rf $backup_path/$database_name-$date_time.sql

echo "压缩后删除原文件 delete $backup_path/$database_name-$date_time.sql" >> $backup_path/dump.log

#找出需要删除的备份
delfile=`ls -l -crt  $backup_path/*.tar.gz | awk '{print $9 }' | head -1`

#判断现在的备份数量是否大于阈值
number=`ls -l -crt  $backup_path/*.tar.gz | awk '{print $9 }' | wc -l`

if [ $number -gt $count ]
then
  #删除最早生成的备份,只保留count数量的备份
  rm $delfile
  #更新删除文件日志
  echo "$date 删除 $count 前的文件 delete $delfile" >> $backup_path/dump.log
fi

crontab内容:

# 频率 sh 脚本路径
# 例如:每天执行一次 backup_mysql.sh 备份脚本
0 0 * * * sh /opt/backup_mysql.sh

🆗完成~


http://www.kler.cn/a/503913.html

相关文章:

  • 导出文件,能够导出但是文件打不开
  • DeepSeek-V3技术报告
  • Vue2+OpenLayers使用Overlay实现点击获取当前经纬度信息(提供Gitee源码)
  • [Deep Learning] Anaconda+CUDA+CuDNN+Pytorch(GPU)环境配置-2025
  • Android SystemUI——服务启动流程(二)
  • 对比学习 (Contrastive Learning) 算法详解与PyTorch实现
  • [Linux] GDB 和 CGDB的使用及理解
  • 国产编辑器EverEdit - 打印与打印预览
  • 如何编写和运行 Lua 脚本优化复杂的 Redis 操作
  • 计算机视觉算法实战——视频分析(Video Analysis)
  • Linux 服务器挖矿木马防护实战:快速切断、清理与加固20250114
  • 【自然语言处理】P1 自然语言处理概述
  • 【SpringSecurity】SpringSecurity安全框架登录校验流程与登录配置示例
  • 时序数据库的订阅对比:TDengine vs InfluxDB 谁更强?
  • CentOS 6.8 安装 Nginx
  • 在ES6模块中导入和导出
  • C语言基本知识复习浓缩版:控制语句--分支
  • Flutter路由动画Hero函数的使用
  • 《利用深度神经网络在广角小口径望远镜中实现天文目标的检测与分类》论文精读
  • 价值尺度如何衡量?
  • “AI 自动化效能评估系统:开启企业高效发展新征程
  • 供应链数字化转型参考大型供应链系统技术架构设计方案
  • PBR(策略路由)的几种使用方式
  • C语言导航 7.2函数的调用
  • 常见的Web GIS地图库
  • C++ NULL和nullptr