【Mysql】Docker下Mysql8数据备份与恢复

news/2025/1/19 11:28:46/文章来源:https://www.cnblogs.com/leovany/p/18337774

目录
  • 【Mysql】Docker下Mysql8数据备份与恢复
  • 1 创建Mysql容器
  • 2 连接Mysql
  • 3 Binlog检查
    • 3.1 检查是否开启
    • 3.2 mysql 5.7
    • 3.3 mysql8
  • 4 备份数据库
    • 4.1 容器里执行备份
    • 4.2 宿主机执行备份
    • 4.3 参数说明
  • 5 定时备份
  • !/bin/bash
  • 按 shift + :
  • 输入 wq

【Mysql】Docker下Mysql8数据备份与恢复

1 创建Mysql容器

  • 格式

    docker run -d
    --name=容器名称 
    -p 宿主端口号:3306 
    -e MYSQL_ROOT_PASSWORD=mysql密码 
    -e MYSQL_PASSWORD=mysql密码
    -e TZ=Asia/Shanghai
    -v 宿主目录-数据:/var/lib/mysql 
    -v 宿主目录-备份数据:/backup 
    --restart always 
    mysql:版本号
    
  • 示例

    docker run -d --name=mysql-8 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_PASSWORD=123456 -e TZ=Asia/Shanghai -v /workspace/mysql-8:/var/lib/mysql -v /workspace/mysql-8-backup:/backup --restart always mysql:8.0
    

2 连接Mysql

  • Navicat

    image-20240714000254341

    • 创建SQL

      -- 删除数据库
      DROP DATABASE IF EXISTS `test`;
      -- 创建数据库
      CREATE DATABASE IF NOT EXISTS `test`;
      -- 进入数据库
      use `test`;
      -- 创建表
      DROP TABLE IF EXISTS `student`;
      CREATE TABLE `student` (`id` bigint NOT NULL AUTO_INCREMENT,`name` varchar(255) DEFAULT NULL,`age` int DEFAULT NULL,PRIMARY KEY (`id`)
      ) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci;
      -- 插入数据
      INSERT INTO `student` (`id`, `name`,`age`) VALUES (1, '小红', '20');
      INSERT INTO `student` (`id`, `name`,`age`) VALUES (2, '小明', '21');
      

3 Binlog检查

3.1 检查是否开启

SHOW VARIABLES like 'log_bin';
  • ON : 开启

  • OFF : 关闭

3.2 mysql 5.7

  • 找到 my.cnf

    find / -name my.cnf 
    
    • docker 位置: /etc/my.cnf
  • 开启

    [mysqld]
    log_bin = mysql-bin
    server_id = 1   # 设置MySQL实例的唯一ID,如果有多个MySQL实例,每个实例的ID必须不同
    

3.3 mysql8

  • 默认开启

4 备份数据库

4.1 容器里执行备份

  • 进入容器

    docker exec -ti mysql-8 /bin/bash
    
  • 在容器内创建备份目录

    前面创建容器时已创建,没有则执行下面

    mkdir /backup
    
  • 全量备份SQL

    mysqldump --single-transaction --flush-logs --source-data=2 --routines --opt -uroot -p123456 test > /backup/test_20240713.sql
    

4.2 宿主机执行备份

  • 格式

    docker exec 容器名 bash -c '命令1 && 命令2'
    
  • 示例

    docker exec mysql-8 bash -c 'mysqldump --single-transaction --flush-logs --source-data=2 --routines --opt -uroot -p123456 test > /backup/test_20240713.sql'
    

4.3 参数说明

  • mysqldump: 这是 mysqldump 命令的执行路径或者别名,用于备份 MySQL 数据库。
  • --single-transaction: 在导出数据时使用单个事务,这样可以确保导出的数据是一个一致性状态的快照,避免了在备份过程中数据变化引起的问题。
  • --flush-logs: 在备份完成后刷新日志文件,这样可以确保备份包含了最新的日志记录。
  • --source-data=2: 指定数据来源的格式,这里是指定为默认格式 2,表示在备份过程中,将主服务器的二进制日志位置信息也备份到文件中。这个参数比较重要,用于在恢复数据时找到位置信息。
    • Mysql 8 : --source-data=2
    • Mysql 5.7 : --master-data=2
  • --routines: 备份存储过程和函数。
  • --opt: 表示使用优化过的备份方式,以提高备份速度和减少备份文件的大小。
  • -uroot: 使用 root 用户连接到 MySQL 数据库。
  • -p: 提示输入密码。
  • test: 要备份的数据库名称,这里假设要备份的数据库名为 test。
  • > backup.sql: 将导出的 SQL 数据写入到 backup.sql 文件中。

5 定时备份

使用crontab定时任务来实现定时备份功能

  • 新建个shell脚本mysql-backup.sh

!/bin/bash

docker exec mysql-8 sh -c 'mysqldump --single-transaction --flush-logs --source-data=2 --routines --opt -uroot -pn2wqeGrlv7 test > /backup/test_$(date +%Y%m%d_%H%M%S).sql'


* 进入crontab

crontab -e


* 添加到定时任务* 每1分钟生效```# mysql备份-每1分钟*/1 * * * * /workspace/cron-jobs/mysql-backup.sh >> /workspace/cron-jobs/mysql-backup.log 2>&1```* 每天凌晨3点生效```mysql备份-每天凌晨3点0 3 * * * /workspace/cron-jobs/mysql-backup.sh >> /workspace/cron-jobs/mysql-backup.log 2>&1```* 保存即时生效

按 shift + :

输入 wq

# 6 恢复数据* 容器内格式:`mysql -uroot -p密码 数据库 < 备份数据库SQL文件路径`

mysql -uroot -p123456 test < /backup/test_20240714_123905.sql


* 宿主机格式:`docker exec -i 容器名 mysql -uroot -p密码 数据库 <  备份数据库SQL文件路径`

docker exec -i mysql-8 mysql -uroot -p123456 test < /workspace/mysql-8-backup/test_20240714_123905.sql

# 7 注意事项## 7.1 定时备份,出现`the input device is not a TTY`* 原因​		"the input device is not a TTY" 错误通常出现在尝试从非交互式的上下文(比如 cron 任务)中运行需要交互的命令时。在你的情况下,可能是你的 Shell 脚本 `mysql-backup.sh` 中包含了需要交互的部分,但是在 cron 任务中无法提供所需的交互。* 解决方案:将脚本中 `docker exec -it` 中去掉 `-it` 即可,表示在容器外部执行命令,而不需要进入容器内开启交互终端。## 7.2 提示:mysqldump: [Warning] Using a password on the command line interface can be insecure.* 原因命令行不能出现密码 `-p123456`* 临时解决方案设置环境密码,然后命令行不在输入密码* 设置环境密码 ```export MYSQL_PWD='123456'```* 去掉密码命令行 `-p密码````docker exec mysql-8 bash -c 'mysqldump --single-transaction --flush-logs --source-data=2 --routines --opt -uroot test > /backup/test_20240713.sql'```​		`export MYSQL_PWD='123456'` 是临时性的设置,适合用于测试、临时任务或者当前会话中的需要。如果你需要更持久的设置,考虑		使用 Dockerfile、Docker Compose 文件或者其他更长久的配置方式来设置环境变量* 长期解决方案1. 创建容器时候加入`-e MYSQL_PASSWORD=密码````docker run --name=mysql-8 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_PASSWORD=123456 --restart always -v /workspace/mysql-8:/var/lib/mysql -v /workspace/mysql-8-backup:/backup -d mysql:8.0```2. 去掉密码命令行 `-p密码````docker exec mysql-8 bash -c 'mysqldump --single-transaction --flush-logs --source-data=2 --routines --opt -uroot test > /backup/test_20240713.sql'```​	

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

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

相关文章

【Windows】安装WSL

1、启用子系统2、商店搜wsl并下载3、重启电脑生效

前端使用 Konva 实现可视化设计器(19)- 连接线 - 直线、折线

本章响应小伙伴的反馈,除了算法自动画连接线(仍需优化完善),实现了可以手动绘制直线、折线连接线功能。本章响应小伙伴的反馈,除了算法自动画连接线(仍需优化完善),实现了可以手动绘制直线、折线连接线功能。请大家动动小手,给我一个免费的 Star 吧~ 大家如果发现了 B…

2024牛客多校第5场

很神奇的场hh,大家一起坐牢,多好啊! B 找规律,这种题一般都是多模拟几个数据然后猜出来#include<bits/stdc++.h> using namespace std;inline int read() {int x=0;bool f=1;char ch=getchar();for(;ch<0||ch>9;ch=getchar())f^=(ch==-);for(;ch>=0&&am…

15. 序列化模块json和pickle、os模块

1. 序列化模块1.1 序列化与反序列化 (1)序列化 将原本的python数据类型字典、列表、元组 转换成json格式字符串的过程就叫序列化 (2)反序列化 将json格式字符串转换成python数据类型字典、列表、元组的过程就叫反序列化 (3)为什么要序列化 计算机文件中没有字典这种数据类…

AI表情神同步!LivePortrait安装配置,一键包,使用教程

快手在AI视频这领域还真有点东西,视频生成工具“可灵”让大家玩得不亦乐乎。现在又开源了一款超好玩的表情同步(表情控制)项目。 一看这图片,就知道是小视频平台出的,充满了娱乐性。发布没几天就已经有8000+Star。项目简介 LivePortrait 是一款由快手团队开发的高效肖像动…

右下角wifi图案点击无可用wifi/更新网卡驱动时遇到错误代码56的解决办法

1.问题 如下图所示,我这里遇到明明有wifi,但是无法检索到任何有用wifi的情况。2.解决方法 参考:电脑WIFI消失,网卡驱动Intel(R) Wi-Fi 6 AX201 160MHz感叹号报错 解决方案集合 —— 无线WI-FI功能缺失,Intel(R) Wi-Fi 6 AX201 160MHz异常,驱动更新错误 2.1 问题原因 当时…

单例模式及其思想

本文包括以下几点↓结论:设计模式不是简单地将一个固定的代码框架套用到项目中,而是一种严谨的编程思想,旨在提供解决特定问题的经验和指导。 单例模式(Singleton Pattern) 意图 旨在确保类只有一个实例,并提供一个全局访问点以访问该实例。 适用性 当你希望系统中只有一…

数组part02

2024年8月1日,今天学习了数组的第二部分。 1.巩固了昨天的双指针问题,即滑动窗口/双指针;注意,双指针是为了减少for循环,使用的时候小心循环的写法和快慢指针的增长方法。 2.学习了数组模拟的螺旋矩阵问题,注意循环不变量; 3.学习了前缀和的方法,前缀和常用来解决区间和…

windwos文件句柄数限制

1、修改注册表,位置如下: HKEY_LOCAL_MACHINE/SOFTWARE/Microsoft/Windows NT/CurrentVersion/Windows2、设置 1、GDIProcessHandleQuota此项设置GDI句柄数量,默认值为2710(16进制)/10000(10进制),该值的允许范围为 256 ~ 16384 ,将其调整为大于默认的10000的值。如果您的…

P5665 [CSP-S2019] 划分

讲解 P5665 [CSP-S2019] 划分。由朴素 dp 入手,先用二分优化,然后用走指针优化,之后注意到单调性,将状态数压缩,然后使用单调队列优化转移。思路: 首先求出 \(a\) 的前缀和数组 \(s\)。 考虑动态规划,令 \(dp_{i,j}\) 表示以 \(i\) 结尾,末尾有 \(j\) 个为一组的最小答…

「代码随想录算法训练营」第二十六天 | 贪心算法 part4

452. 用最少数量的箭引爆气球题目链接:https://leetcode.cn/problems/minimum-number-of-arrows-to-burst-balloons/ 题目难度:中等 文章讲解:https://programmercarl.com/0452.用最少数量的箭引爆气球.html 视频讲解:https://www.bilibili.com/video/BV1SA41167xe 题目状态…