Docker中配置Mysql主从备份

Mysql配置主从备份


一、Docker中实现跨服务器主从备份

在 Docker 中配置 MySQL 主从备份主要通过 MySQL 主从复制实现

二、配置步骤

1.配置主库

复制代码
# 进入mysql主库容器
docker exec -it mysql-master bash

# 连接mysql
mysql -127.0.0.1 ip -P 3306 -uroot -p 'password'

# 创建用于从库连接的用户
CREATE USER 'replica_user'@'%' IDENTIFIED WITH 'mysql_native_password' BY 'replica_password';
GRANT REPLICATION SLAVE ON *.* TO 'replica_user'@'%';
FLUSH PRIVILEGES;

# 检查二进制日志状态(记录File和Position)
SHOW MASTER STATUS;

2.配置从库

复制代码
# 进入mysql主库容器
docker exec -it mysql-slave bash

# 连接mysql
mysql -127.0.0.1 ip -P 3306 -uroot -p 'password'

-- 配置从库连接到主库
CHANGE MASTER TO
  MASTER_HOST='mysql-master',
  MASTER_PORT=3306,
  MASTER_USER='replica_user',
  MASTER_PASSWORD='replica_password',
  MASTER_LOG_FILE='binlog.000003',
  MASTER_LOG_POS=932570,
  GET_MASTER_PUBLIC_KEY=1;

-- 启动从库复制
START SLAVE;

# 查看状态
SHOW SLAVE STATUS\G;

# 检查复制状态:确认以下两项为 Yes,表示复制成功
# Slave_IO_Running: Yes
# Slave_SQL_Running: Yes

3.遇到问题

Fatal error: The replica I/O thread stops because source and replica

have equal MySQL server ids; these ids must be different for

replication to work (or the --replicate-same-server-id option must be

used on replica but this does not always make sense; please check the

manual before using it).

  • 主库与从库的id重复了,可以修改主库或者从库的id(mysql默认配置server-id=1)
    • 修改从数据库配置文件

mysqld

server-id=2

log-bin=mysql-bin

binlog-format=row

sql_mode=STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION

  • 重启mysql容器
复制代码
docker restart mysql-slave

- 使用配置遇到提醒

mysql: Warning World-writable config file '/etc/mysql/my.cnf' is ignored.

这个警告 mysql: Warning World-writable config file '/etc/mysql/my.cnf' is ignored. 通常表示 MySQL 配置文件 /etc/mysql/my.cnf 的权限设置不安全。MySQL 出于安全原因,会忽略权限设置为 "world-writable"(任何人都可写)的配置文件。

  • 进入容器修改权限
复制代码
docker exec -it mysql-server bash
chmod 644 /etc/mysql/my.cnf

3.其它使用到的命令

  • 删除主从配置

    停止从库的复制线程

    STOP SLAVE;

    清除主从复制配置

    RESET SLAVE ALL;

相关推荐
南墙上的石头9 小时前
麒麟 V10 重装人大金仓 V8R6 踩坑实录(含 MySQL 兼容模式)
数据库·mysql
执子手 吹散苍茫茫烟波11 小时前
RC 隔离级别下 MySQL InnoDB 死锁典型案例
数据库·mysql
梦梦代码精11 小时前
电商系统不是技术堆叠:LikeShop如何用分层Hold住复杂业务?
java·docker·代码规范
zhoupenghui16814 小时前
【AI大模型应用开发】【项目实战】13.RAG智慧问答项目-(一)项目介绍&项目架构&项目环境配置
人工智能·docker·ai·milvus·rag·attu·rag智慧问答项目
峥无15 小时前
深入理解MySQL事务与MVCC机制
数据库·mysql
江畔柳前堤16 小时前
第13章:docker生产环境部署实战
运维·git·docker·容器·代码复审
要开心吖ZSH18 小时前
MVCC 进阶:快照读 vs 当前读、幻读与 Next-Key Lock
java·数据库·sql·mysql·mvcc
万亿少女的梦16818 小时前
基于Spring Boot的天空影院电影网站系统设计与实现
java·spring boot·mysql·vue·系统设计
hj28625118 小时前
Docker 容器化技术标准化笔记
java·笔记·docker
万亿少女的梦16818 小时前
基于Spring Boot的社区管理系统设计与实现
java·spring boot·mysql·vue·系统设计