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

数据库备份-docker配置主从数据库

创建 Docker Compose 文件

创建一个 docker-compose.yml 文件,定义两个 MySQL 容器(一个主库,一个从库)

services:mysql:image: mysql:8.0.27container_name: mysqlports:- "3306:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123456MYSQL_DATABASE: life_spaceMYSQL_USER: replica_userMYSQL_PASSWORD: 123456volumes:- "./mysql/conf:/etc/mysql/conf.d"- "./mysql/data:/var/lib/mysql"- "./mysql/backup:/backup"- "./mysql/init:/docker-entrypoint-initdb.d"networks:- life_spacecommand: --server-id=1 --log-bin=mysql-bin --binlog_do_db=life_space
​mysql-slave:image: mysql:8.0.27container_name: mysql-slaveports:- "3307:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123456MYSQL_DATABASE: life_spaceMYSQL_USER: replica_userMYSQL_PASSWORD: 123456volumes:- "./mysql-slave/data:/var/lib/mysql"- "./mysql-slave/backup:/backup"
​networks:- life_spacecommand: --server-id=2 --relay-log=mysql-relay-bin --log-bin=mysql-bin --binlog_do_db=life_space
​

3 配置MySQL-SSL

创建自定义配置文件:/etc/mysql/conf.d/ls-mysql.cnf。添加如下内容;

[mysqld]
ssl-ca=/var/lib/mysql/ca.pem
ssl-cert=/var/lib/mysql/server-cert.pem
ssl-key=/var/lib/mysql/server-key.pem

4 启动 MySQL 容器

docker-compose.yml 文件所在目录下,运行以下命令启动容器:

docker-compose up -d

5. 配置主库(Master)

5.1 进入主库容器
docker exec -it mysql-master mysql -uroot -prootpassword
5.2 创建复制用户

在主库中创建用于复制的用户:

CREATE USER 'replica_user'@'%' IDENTIFIED BY '123456';
GRANT REPLICATION SLAVE ON *.* TO 'replica_user'@'%';
FLUSH PRIVILEGES;
5.3 获取主库状态

在主库中执行以下命令,记录 FilePosition 的值:

SHOW MASTER STATUS;

输出示例:

Binlog_Do_DB:life_space 指的就是要备份的数据库,这很重要!!!

+------------------+----------+--------------+------------------+-------------------+
| File             | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+------------------+----------+--------------+------------------+-------------------+
| mysql-bin.000005 |      156 | life_space   |                  |                   |
+------------------+----------+--------------+------------------+-------------------+
​

6. 配置从库(Slave)

6.1 进入从库容器
docker exec -it mysql-slave mysql -uroot -p123456
6.2 配置从库连接主库

在从库中执行以下命令,配置从库连接主库:

sql

STOP SLAVE;
​
CHANGE MASTER TO
MASTER_HOST='mysql',
MASTER_USER='replica_user',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000006',
MASTER_LOG_POS=156,
MASTER_SSL=1,
MASTER_SSL_CA='/var/lib/mysql/ca.pem',
MASTER_SSL_CERT='/var/lib/mysql/client-cert.pem',
MASTER_SSL_KEY='/var/lib/mysql/client-key.pem';
6.3 启动从库复制

在从库中启动复制:

START SLAVE;
6.4 检查从库状态

在从库中执行以下命令,检查复制状态:

SHOW SLAVE STATUS\G;

重点关注以下字段:

  • Slave_IO_Running:应为 Yes

  • Slave_SQL_Running:应为 Yes

  • Seconds_Behind_Master:表示从库与主库的延迟时间,通常应为 0


相关文章:

  • IntelliJ IDEA右键快捷方式设置方法
  • Sentinel源码—5.FlowSlot借鉴Guava的限流算法二
  • uniApp小程序保存定制二维码到本地(V3)
  • YOLOv11改进有效涨点专栏:从理论到实战的深度优化指南
  • docker转移镜像
  • 那就聊一聊mysql的锁
  • 【基于Fluent+Python耦合的热管理数字孪生系统开发:新能源产品开发的硬核技术实践】
  • CMFA在自动驾驶中的应用案例
  • 国产的 Java Solon v3.2.0 发布(央企信创的优选)
  • Go-zero框架修改模版进行handler统一响应封装
  • Python基于知识图谱的医疗问答系统【附源码、文档说明】
  • A股周度复盘与下周策略 的deepseek提示词模板
  • VsCode搭建
  • ueditorplus编辑器已增加AI智能
  • Java Date 类深度解析
  • ISO26262-浅谈用例导出方法和测试方法
  • x-ui重新申请ssl证书失败
  • c++冒泡排序实现
  • 部署rocketmq集群
  • 高效的项目构建:用 Makefile 自动化你的构建过程
  • 大理杨徐邱再审后上诉案将于下周开庭:案发已逾32年,故意杀人罪去年被撤销
  • 央视网评论员:婚约不是性许可——山西订婚强奸案背后的性教育盲区
  • 让观众从演唱会现场走到商场,上海虹口构建“票根经济”生态链
  • 青创上海-2025浦东徒步行倒计时1天,明日浦东世博文化公园不见不散
  • 上海出台26项措施促进民营经济高质量发展,关于公平竞争、融资支持等
  • 昆明一垃圾车致人身亡事故调查报告:驻车制动装置失效,司机欲阻停被撞