备份Docker部署的MySQL

文章目录

  • 一、MySQL备份脚本
    • 1.本地部署的MySQL
      • 1.1 备份脚本
      • 1.2 添加权限
      • 1.3 执行脚本
      • 1.4 计划任务自动备份(可选)
    • 2.备份Docker部署的MySQL

一、MySQL备份脚本

1.本地部署的MySQL

1.1 备份脚本

# vi mysql_backup.sh
#!/bin/bash  
# MySQL连接参数  
USER="MySQL用户名"  
PASSWORD="MySQL密码"  
HOST="主机地址"  
PORT="3306"  
DATABASE="数据库名"  # 备份文件存放目录  
BACKUP_DIR="/mnt/backup/mysql"  # 当前的日期时间,用于备份文件名  
DATE=$(date +"%Y%m%d%H%M%S")  # 完整的备份文件名  
BACKUP_FILE="$BACKUP_DIR/backup_$DATABASE_$DATE.sql"  # 检查备份目录是否存在,如果不存在则创建  
if [ ! -d "$BACKUP_DIR" ]; then  mkdir -p "$BACKUP_DIR"  echo "已创建备份目录: $BACKUP_DIR"  
fi  # 使用mysqldump进行备份  
mysqldump -h$HOST -P$PORT -u$USER -p$PASSWORD $DATABASE > "$BACKUP_FILE"  # 检查备份是否成功  
if [ $? -eq 0 ]; then  echo "数据库 $DATABASE 已成功备份到 $BACKUP_FILE"  
else  echo "备份数据库时出错 $DATABASE"  
fi  # (可选)删除旧的备份文件,例如只保留最近7天的备份  
# find $BACKUP_DIR -name "backup_$DATABASE_*.sql" -mtime +7 -delete

1.2 添加权限

# 添加执行权限
chmod +x mysql_backup.sh

1.3 执行脚本

./mysql_backup.sh

1.4 计划任务自动备份(可选)

# 每周六凌晨一点自动执行数据库备份脚本
# crontab -e
0 1 * * 6  /mnt/mysql_backup.sh

2.备份Docker部署的MySQL

注:如果MySQL是docker部署的,需将上方"1.1"数据库备份脚本拷贝到MySQL容器内执行。

# 将脚本复制到容器中  
docker cp ./mysql_backup.sh $CONTAINER_NAME_OR_ID:/tmp/ 
例:docker cp ./mysql_backup.sh  mysql:/tmp/
# 在容器中执行脚本  
# 注意:这里我们不需要-it选项,因为我们只是要执行命令,而不是交互式shell  
docker exec -it $CONTAINER_NAME_OR_ID  /bin/bash -c "/tmp/mysql_backup.sh"  例:# docker exec -it  mysql  /bin/bash -c "/tmp/mysql_backup.sh"mysqldump: [Warning] Using a password on the command line interface can be insecure.数据库 oneapi 已成功备份到 /mnt/backup/mysql/backup_20240531095450.sql
# 如果LATEST_BACKUP_FILE为空,说明没有找到任何备份文件  
docker cp $CONTAINER_NAME_OR_ID:$BACKUP_DIR_IN_CONTAINER/$LATEST_BACKUP_FILE  $LOCAL_BACKUP_DIR/  
例:docker cp  mysql:/mnt/backup/mysql/backup_20240531095450.sql ./

注:脚本默认备份数据在docker容器中也有一份,为了避免备份文件占用mysql容器空间,建议登录容器中删除。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/23507.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C++中成员函数和变量的存储、this指针的使用和const关键词以及常对象

文章目录 1.成员变量和成员函数分开存储2.this指针1.概念2.链式调用 3.空指针调用成员函数4.const修饰成员函数5.常对象 1.成员变量和成员函数分开存储 成员变量: 成员变量是类的数据部分,它们存储了类的实例(对象)的状态信息。当…

Qt图标字体文件中提取字体保存为图片

本文借用别人写的一个IconHelper来做说明。 1. 加载一个字体文件 QScopedPointer<IconHelper> iconHelper(new IconHelper(":/fa-regular-400.ttf", "Font Awesome 6 Pro Regular"));构造函数 IconHelper::IconHelper(const QString &fontFile…

【基础】LwM2M 通讯协议

【基础】LwM2M 通讯协议 LwM2M 协议基础LwM2M 简介LwM2M 基本架构LwM2M 资源定义 LwM2M 协议实现开源协议实现Java LwM2M Client LwM2M 协议基础 LwM2M 简介 LwM2M 的全称为 Lightweight Machine-To-Machine&#xff0c;是一种适用于物联网设备的轻量级的通讯协议&#xff0c…

Flutter基础 -- Flutter布局练习(小项目)

目录 1. Splash 布局&#xff08;第一页&#xff09; 1.1 目标 1.2 当前效果图 1.3 创建 Splash 界面 1.4 设置 MaterialApp 1.5 设置 Splash 背景色 1.6 布局 Splash 界面 1.7 总结 2. Splash 圆角图片 2.1 目标 2.2 当前效果图 2.3 蓝湖下载图片 2.4 图片导入项…

在编程Python的时候发生ModuleNotFoundError: No module named distutils报错怎么办

1.先查看Python版本 首先我们先去打开终端就是先widr再输入cmd 然后进去在输入Python -V要注意大小写 我的版本是3.9.7版本但是我使用的PyCharm 是 2021.1.1 x64版本没有办法主动去识别因为这个版太低了你的Python版本很高所以无法识别 2.解决方法 只需要把你的Python现版…

微信公众号【原子与分子模拟】: 熔化温度 + 超导电性 + 电子化合物 + 分子动力学模拟 + 第一性原理计算 + 数据处理程序

往期内容主要涵盖&#xff1a; 熔化温度 超导电性 电子化合物 分子动力学模拟 第一性原理计算 数据处理程序 【1】熔化温度 分子动力学 LAMMPS 相关内容 【文献分享】分子动力学模拟 LAMMPS 熔化温度 晶体缺陷 熔化方法 LAMMPS 文献&#xff1a;金属熔化行为的局域…

后端返回图片格式乱码

try {const response await request.get(checkCodeUrl.value,{responseType:"arraybuffer"});console.log("验证码请求成功:", response);checkCodeUrl.value data: image/jpeg;base64,${btoa(new Uint8Array(response).reduce((data, byte) > data …

『大模型笔记』大型语言模型(LLMs)微调(Fine-tuning)优化研究!

大型语言模型(LLMs)微调(Fine-tuning)优化研究! 文章目录 一. 摘要二. 大模型优化技术概述2.1 梯度检查点(Gradient Checkpointing)2.2 低秩适应2.3 DeepSpeed2.4 Flash Attention三. GPU内存需求的理论分析3.1. 模型状态内存(Model states memory) - 模型参数、梯度、优化器状…

vscode ctrl+鼠标左键无法跳转

打开设置&#xff0c;搜索intel…… 将这个智能感知改成default就可以了&#xff0c;我之前是在disable处。 分析了一下&#xff0c;其实跳转功能主要是根据上下文语法分析来实现的&#xff0c;并不是简单得全文匹配&#xff0c;因此需要相关得语法分析工具。 那么为什么默认式…

微软Edge浏览器深度解析:功能、同步、隐私与安全

微软Edge浏览器是微软公司开发的一款网页浏览器,它基于Chromium内核,提供了快速、安全和兼容性良好的网页浏览体验。以下是关于微软Edge浏览器的详细信息和使用指南: 微软Edge浏览器的主要特点: 1. 基于Chromium内核: 渲染引擎:Chromium内核是基于开源项目Blink的,它…

可视化数据科学平台在信贷领域应用系列五:零代码可视化建模

信贷风控模型是金融机构风险管理的核心工具&#xff0c;在信贷风险管理工作中扮演着至关重要的角色。随着信贷市场的环境不断变化&#xff0c;信贷业务的风险日趋复杂化和隐蔽化&#xff0c;开发和应用准确高效的信贷风控模型显得尤为重要。信贷风险控制面临着越来越大的挑战和…

问你为什么选择Kafka,你会怎么回答?

可靠的含义在百度百科的解释是&#xff1a;可以信赖、可以相信、可靠的朋友。那Kafka究竟是不是一个可靠的朋友呢&#xff1f;既然全世界绝大部分高可用系统都有Kafka的支持&#xff0c;Kafka必定有其过人之处&#xff0c;跟着我来分析分析。 另外多提一嘴Kafka在GitHub目前已…

六西格玛培训,带你解锁职场超能力工具!

当提及六西格玛培训的精髓时&#xff0c;我们不得不提到那些强大而实用的工具&#xff0c;它们如同探险者的指南针&#xff0c;引导我们走向卓越。今天&#xff0c;就让我们一起揭开这些神秘工具的面纱&#xff0c;探寻六西格玛背后的智慧。 首先&#xff0c;DMAIC流程是六西格…

python小游戏:猜数字、猜动物、单词接龙(带界面)

正在学习python的各位童鞋&#xff0c;可以多多找些程序来练练手&#xff0c;从而更快的掌握python编程。这里就为大家找了三个示例小程序&#xff1a;猜数字、猜动物、单词接龙。 一、猜数字 程序会随机生成一个1到100之间的数字&#xff0c;然后让用户尝试猜测这个数字。用户…

cesium 漫游

token记得换成您自己的&#xff01;&#xff01;&#xff01; 申请cesium的token 官网【Cesium: The Platform for 3D Geospatial】 <template><div id"cesiumContatiner"><!-- <div id"mapContainer1"></div> --></di…

如何理解敏捷开发和瀑布模型的区别

敏捷开发和瀑布模型是两种不同的软件开发方法&#xff0c;它们在多个方面存在显著的差异。以下是它们之间的主要区别&#xff1a; 开发流程&#xff1a; 瀑布模型&#xff1a;采用线性的开发流程&#xff0c;按照预先规划的顺序依次进行需求分析、设计、编码、测试和维护等环节…

【蒙特卡洛仿真的corner】

蒙特卡洛仿真的corner global variation指的是不同晶圆之间的process的差别 local variation指的是同一个晶圆内的不同管子之间的mismatch smic40ll工艺中&#xff0c;ttg&#xff0c;ssg&#xff0c;sfg&#xff0c;fsg corner只包含mismatch ss&#xff0c;tt&#xff0c;sf&…

员工离职删除自己做的文件违法么?如何杜绝这种现象?

员工离职时删除自己做的文件是否违法&#xff0c;需要视情况而定&#xff1a; 如果删除的是个人自己的文件&#xff1a; 在这种情况下&#xff0c;员工删除的是自己制作的、不涉及公司机密或经营数据的个人文件&#xff0c;通常不会被视为违法行为。 如果删除的是公司的文件…

探索 CSV 模块:Python 中 CSV 数据持久化的最佳实践

&#x1f340; 前言 博客地址&#xff1a; CSDN&#xff1a;https://blog.csdn.net/powerbiubiu &#x1f44b; 简介 本章节介绍使用 CSV 文件来存储数据&#xff0c;CSV 文件是一种常见的数据格式&#xff0c;可以用来存储和交换表格数据。CSV 文件由一系列的行组成&#x…

SQL Developer管理RESTful 服务

RESTful 服务依赖于ORDS&#xff08;Oracle REST Data Services&#xff09;&#xff0c;所以在进行本实验前&#xff0c;请先确认数据库服务器上的ORDS服务已启动&#xff1a; $ systemctl status ords ● ords.service - Oracle REST Data ServicesLoaded: loaded (/etc/sys…