Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >docker 搭建mysql主从复制

docker 搭建mysql主从复制

作者头像
用户10125653
发布于 2022-11-10 13:56:29
发布于 2022-11-10 13:56:29
56500
代码可运行
举报
文章被收录于专栏:changechange
运行总次数:0
代码可运行

主从复制概述

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

主从复制原理

  • 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
代码运行次数:0
运行
AI代码解释
复制
[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
代码运行次数:0
运行
AI代码解释
复制
[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;

重启从容器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
代码运行次数:0
运行
AI代码解释
复制
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;

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

测试主从复制

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

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

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

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

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【云原生】docker安装mysql实现主从复制
 ​新建主服务器容器实例3307 docker run -p 3307:3306 --name mysql-master \ -v /mydata/mysql-master/log:/var/log/mysql \ -v /mydata/mysql-master/data:/var/lib/mysql \ -v /mydata/mysql-master/conf:/etc/mysql \ -e MYSQL_ROOT_PASSWORD=root  \ -d mysql:5.7 进入/mydat
一个风轻云淡
2022/11/15
3410
【云原生】docker安装mysql实现主从复制
【保姆级】docker安装MySQL主从复制
命令解读: docker run :创建并运行一个容器 –name : 给容器起一个名字,比如叫做abc -p :将宿主机端口与容器端口映射,冒号左侧是宿主机端口,右侧是容器端口 -d:后台运行容器 -e:环境变量,如密码什么的 -v:挂载一个数据卷到某个容器内目录,上面分别配置了日志、数据、配置的数据卷
害恶细君
2022/11/22
2.4K1
【保姆级】docker安装MySQL主从复制
docker搭建mysql主从
mysql主从 # 主mysql启动 docker run --privileged=true -d -p 3307:3306 --name='mysql_master' \ -e MYSQL_ROOT_PASSWORD=123456 \ -v /opt/mysql_master/log:/var/log/mysql \ -v /opt/mysql_master/data:/var/lib/mysql \ -v /opt/mysql_master/conf:/etc/mysql/conf.d mysql
buiu
2022/01/30
6440
结合实战,我为MySQL主从复制总结了几张图!
作者个人研发的在高并发场景下,提供的简单、稳定、可扩展的延迟消息队列框架,具有精准的定时任务和延迟队列处理功能。自开源半年多以来,已成功为十几家中小型企业提供了精准定时调度方案,经受住了生产环境的考验。为使更多童鞋受益,现给出开源框架地址:
冰河
2020/12/24
6610
结合实战,我为MySQL主从复制总结了几张图!
MySQL主从复制
修改mysql配置文件,不同的系统my.cnf路径不同(CentOS中位于/etc/my.cnf)
十毛
2019/03/27
1.8K0
MySql主从复制,从原理到实践!
主从复制是指将主数据库的DDL和DML操作通过二进制日志传到从数据库上,然后在从数据库上对这些日志进行重新执行,从而使从数据库和主数据库的数据保持一致。
macrozheng
2020/01/16
5410
MySql主从复制,从原理到实践!
docker搭建mysql主从复制
进入/mydata/mysql-master/conf目录下新建my.cnf(上面启动容器实例指定的路径)
别团等shy哥发育
2023/02/25
7020
docker搭建mysql主从复制
docker高级篇(大厂进阶):安装mysql主从复制
步骤2中进入/mydata/mysql-master/conf目录下新建my.cnf -> vim my.cnf
刘大猫
2024/12/18
1410
基于Docker实现MySQL主从复制
注意server-id必须是一个唯一的数字,必须主从不一致, 且主从库必须设置项。
Java_老男孩
2019/12/02
6650
基于Docker实现MYSQL主从复制
注意 server-id必须是一个唯一的数字,必须主从不一致, 且主从库必须设置项。
Bug开发工程师
2019/11/12
6000
Mysql主从复制搭建与深度原理分析
首先,在docker下进行搭建mysql可以当做学习数据库搭建时的测试使用,docker的hub中有已经封装好的mysql可以避免我们进行数据库安装的复杂步骤,而且docker容器之间相互独立,拥有自己的ip和可以设置不同的端口,不会造成端口的冲突。
Tim在路上
2020/08/04
4350
MySQL主从复制学习小记
MySQL 主从复制(replication)是一个异步的复制过程。从一个实例(Master)复制到另一个实例(Slave),整个过程需要由 Master 上的 IO 进程 和 Slave 上的 Sql 进程 与 IO 进程 共同完成。 首先 Master 端必须打开 binary log(bin-log),因为整个复制过程实际上就是 Slave 端从 Master 端获取相应的二进制日志,然后在本地完全顺序的执行日志中所记录的各种操作。 原理图如下:
芈亓
2023/09/26
2530
MySQL主从复制学习小记
docker高级篇1-dockeran安装mysql主从复制
大家好,咱们前面通过十篇的文章介绍了docker的基础篇,从本篇开始,咱们的《docker学习系列》将要进入到高级篇阶段(基础篇大家可以查看之前发布的文章)。
凯哥Java
2022/12/20
9720
docker高级篇1-dockeran安装mysql主从复制
《docker高级篇(大厂进阶):1.Docker复杂安装详说》包括:安装mysql主从复制、安装redis集群
步骤2中进入/mydata/mysql-master/conf目录下新建my.cnf -> vim my.cnf
刘大猫
2024/12/30
660
MySQL主从复制详解
在MySQL中,主从架构应该是最基础、最常用的一种架构了。后续的读写分离、多活高可用架构等大多都依赖于主从复制。主从复制也是我们学习MySQL过程中必不可少的一部分,关于主从复制的文章有很多,笔者也来凑凑热闹,写写这方面的内容吧,同时分享下自己的经验和方法。
MySQL技术
2020/07/28
4170
MySQL主从复制详解
Mysql主从复制
(1)主从服务器操作系统版本和位数必须一致; (2)主节点(Master)和从节点(Slave)数据库版本必须一致; (3)主节点(Master)和从节点(Slave)数据库中的数据必须一致; (4)主节点(Master)需要开启二进制日志; (5)主节点(Master)和从节点(Slave)的 server-id 在局域网内必须唯一。
码客说
2022/12/05
1.2K0
Mysql主从复制
MySQL主从复制配置
Mysql中有一种日志叫做bin日志(二进制日志)。这个日志会记录下所有修改了数据库的SQL语句(INSERT,UPDATE,DELETE,ALTER TABLE,GRANT等等)。
Java帮帮
2018/12/24
4730
Docker手把手教你搭建MySQL集群【主从复制】
原理:主从复制是指一台服务器充当主数据库服务器,另一台或多台服务器充当从数据库服务器,主服务器中的数据自动复制到从服务器之中。对于多级复制,数据库服务器即可充当主机,也可充当从机。MySQL主从复制的基础是主服务器对数据库修改记录二进制日志,从服务器通过主服务器的二进制日志自动执行更新。1、新建主服务器示例3307docker run -p 3307:3306 --name mysql-master \-v /mydata/mysql-master/log:/var/log/mysql \-v /mydat
小熊学Java
2022/09/04
6980
高可用架构-- MySQL主从复制的配置
环境 操作系统:CentOS-6.6-x86_64-bin-DVD1.iso MySQL版本:mysql-5.6.26.tar.gz 主节点IP:192.168.1.205 主机名:edu-mysql-01 从节点IP:192.168.1.206 主机名:edu-mysql-02 主机配置:4核CPU、4G内存 依赖课程 《高可用架构篇--第13节--MySQL源码编译安装(CentOS-6.6+MySQL-5.6)》 MySQL主从复制官方文档 http://dev.mysql.com/doc/refma
思梦php
2018/03/09
1.7K0
高可用架构-- MySQL主从复制的配置
Docker高级篇笔记(六)在docker里面进行mysql的主从复制
我们要使用docker搭建一个mysql的主从复制,那么就相当于要创建两个容器,一个是主的,一个是从的
一写代码就开心
2022/05/09
3780
Docker高级篇笔记(六)在docker里面进行mysql的主从复制
相关推荐
【云原生】docker安装mysql实现主从复制
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验