前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >docker 搭建mysql主从复制

docker 搭建mysql主从复制

作者头像
用户10125653
发布2022-11-10 21:56:29
4940
发布2022-11-10 21:56:29
举报
文章被收录于专栏:change

主从复制概述

  • 主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(也叫重做),从而使得从库和主库的数据保持同步。
  • MySQL支持一台主库同时向多台从库进行复制, 从库同时也可以作为其他从服务器的主库,实现链状复制。
  • MySQL 复制的优点主要包含以下三个方面:
  1. 主库出现问题,可以快速切换到从库提供服务。
  2. 实现读写分离,降低主库的访问压力。
  3. 可以在从库中执行备份,以避免备份期间影响主库服务。

主从复制原理

image.png
image.png
  • Master 主库在事务提交时,会把数据变更记录在二进制日志文件 Binlog 中。
  • 从库读取主库的二进制日志文件 Binlog ,写入到从库的中继日志 Relay Log 。
  • slave重做(对这些日志重新执行)中继日志中的事件,从而使得从库和主库的数据保持同步。

环境搭建

  • 下载mysql镜像

docker pull mysql:latest

  • 运行mysql主容器

sudo docker run -p 3307:3306 --name main_mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql

  • 运行mysql从容器

sudo docker run -p 3308:3306 --name slave_mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql

修改主容器配置

  • 进入主从容器

sudo docker exec -it main_mysql bin/bash

  • 更新软件

apt-get update

  • 下载vim编辑器

apt-get vim

  • 修改主容器mysql配置文件

vim /etc/mysql/my.cof

代码语言:javascript
复制
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=101 
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能
log-bin=mall-mysql-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062

修改从容器配置

  • 进入从容器

sudo docker exec -it slave_mysql bin/bash

  • 更新软件

apt-get update

  • 下载vim编辑器

apt-get vim

  • 修改从容器mysql配置文件

vim /etc/mysql/my.cof

代码语言:javascript
复制
[mysqld]
## 设置server_id,同一局域网中需要唯一
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql  
## 开启二进制日志功能,以备Slave作为其它数据库实例的Master时使用
log-bin=mall-mysql-slave1-bin  
## 设置二进制日志使用内存大小(事务)
binlog_cache_size=1M  
## 设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed  
## 二进制日志过期清理时间。默认值为0,表示不自动清理。
expire_logs_days=7  
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断。
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062  
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin  
## log_slave_updates表示slave将复制事件写进自己的二进制日志
log_slave_updates=1  
## slave设置为只读(具有super权限的用户除外)
read_only=1

重启主容器mysql

  • 重启命令

docker restart main_mysql

  • 进入容器

docker exec -it main_mysql /bin/bash

  • 进入mysql

mysql -u root -p root

  • 创建数据同步用户

CREATE USER 'slave'@'%' IDENTIFIED BY '123456';

  • 用户授权

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'slave'@'%';

  • 配置刷新

flush privileges;

  • 在主数据库中查看主从同步状态

show master status;

image.png
image.png

重启从容器mysql

  • 重启命令

docker restart salve_mysql

  • 进入容器

docker exec -it salve_mysql /bin/bash

  • 进入mysql

mysql -u root -p root

  • 在从数据库中配置主从复制

change master to master_host='宿主机ip', master_user='slave', master_password='123456', master_port=3307, master_log_file='mysql-slave-bin.000002', master_log_pos=3860, master_connect_retry=30;

代码语言:javascript
复制
master_host 为主容器的ip(docker 查询容器ip命令:docker inspect  main_mysql | grep IPAddress)
master_user 为主容器mysql的用户名
master_password 为主容器mysql的密码
master_log_file 为主容器mysql的File(mysql-slave-bin.000002)
master_log_pos 未主容器的Position(3860)
master_connect_retry 连接主容器的次数
  • 启动slave

start slave

  • 在从数据库中查看主从同步状态

show slave status \G;

image.png
image.png

当Slave_ID_Running: YES 和 Slave_SQLRunning:YES 都为YES 时,说明主从复制已经搭建成功了 其中有个为NO 可以看下方报错日志,查询相关文档进行排错。

测试主从复制

  • 在主容器mysql中创建user表,从容器中user也同步创建了
image.png
image.png
  • 在主容器user表中插入数据,从容器user数据也跟着插入了
image.png
image.png
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 主从复制概述
  • 主从复制原理
  • 环境搭建
  • 修改主容器配置
  • 修改从容器配置
  • 重启主容器mysql
  • 重启从容器mysql
  • 测试主从复制
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档