docker 搭建mysql集群一主一从,两台机器

一、准备两条机器,分别为IP1和IP2,其中IP1为主,IP2为从

二、在两台机器上分别拉取mysql镜像

复制代码
docker pull mysql:8.0.29

三、在home目录下新建目录,分别为/home/mysql/data,/home/mysql/conf

1、在IP1主机下的/home/mysql/conf目录下新建my.cnf文件,内容为

复制代码
[mysqld]
server-id=1
 
#binlog_format=STATEMENT
 
#这里需要注意,因为STATEMENT 性能是最好的,但是我们需要使用canal,所以这里需要使用row格式,如果不需要使用可以使用STATEMENT
binlog_format=row

2、在IP2从机的/home/mysql/conf目录下新建my.cnf文件,内容为

复制代码
[mysqld]
# 服务器唯一id,每台服务器的id必须不同,如果配置其他从机,注意修改id
server-id=2
# 中继日志名,默认xxxxxxxxxxxx-relay-bin
#relay-log=relay-bin

四、在主机目录下执行如下操作:

1、运行生产docker容器:

复制代码
docker run -d \
-p 3306:3306 \
-v /home/mysql/conf:/etc/mysql/conf.d \
-v /home/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=xxxxxx \
--name mysql-master \
mysql:8.0.29

2、进入容器

复制代码
docker exec -it mysql-master /bin/bash 

docker exec -it mysql-master /bin/bash 

mysql - uroot - pxxxxxx

3、在主机中创建slave用户

复制代码
-- 创建slave用户
CREATE USER 'mytest'@'%';
-- 设置密码
ALTER USER 'mytest'@'%' IDENTIFIED WITH mysql_native_password BY 'zzzzzzz';
-- 授予复制权限
GRANT REPLICATION SLAVE ON *.* TO 'mytest'@'%';
-- 刷新权限
FLUSH PRIVILEGES;

4、主机中查询master状态,一定要记住,仓库配置时需要

复制代码
SHOW MASTER STATUS;

五、在从机执行如下:

1、运行容器

复制代码
docker run -d \
-p 3306:3306 \
-v /home/mysql/conf:/etc/mysql/conf.d \
-v /home/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=xxxxxx \
--name mysql-slave \
mysql:8.0.29

2、进入容器

复制代码
docker exec -it mysql-slave /bin/bash

mysql -uroot -ptcdri123

3、在从机上配置主从关系

复制代码
CHANGE MASTER TO MASTER_HOST='IP1', 
MASTER_USER='mytest',MASTER_PASSWORD='zzzzzz', MASTER_PORT=3306,
MASTER_LOG_FILE='binlog.000002',MASTER_LOG_POS=1054;

注:此处的用户为在主机中创建的slave用户名和密码

4、启动主从同步并查看状态

复制代码
START SLAVE;

SHOW SLAVE STATUS\G

五、至此基本上就配置完成了,使用如下验证

复制代码
CREATE DATABASE db_user;
USE db_user;
CREATE TABLE t_user (
 id BIGINT AUTO_INCREMENT,
 uname VARCHAR(30),
 PRIMARY KEY (id)
);

在主库创建完成以后,会发现从库中也生成了对应的表,主库插入用户在从库也会生成对应的用户。

六、停止和重置

需要的时候,可以使用如下SQL语句

复制代码
-- 在从机上执行。功能说明:停止I/O 线程和SQL线程的操作。
stop slave; 
 
-- 在从机上执行。功能说明:用于删除SLAVE数据库的relaylog日志文件,并重新启用新的relaylog文件。
reset slave;
 
-- 在主机上执行。功能说明:删除所有的binglog日志文件,并将日志索引文件清空,重新开始所有新的日志文件。
-- 用于第一次进行搭建主从库时,进行主库binlog初始化工作;
reset master;
相关推荐
Yang-Never2 小时前
Kotlin协程 -> Job.join() 完整流程图与核心源码分析
android·开发语言·kotlin·android studio
luckys.one3 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
jakeswang7 小时前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
一成码农7 小时前
MySQL问题7
数据库·mysql
一笑的小酒馆7 小时前
Android性能优化之截屏时黑屏卡顿问题
android
慕容晓开8 小时前
docker,本地目录挂载
docker
Kt&Rs8 小时前
MySQL复制技术的发展历程
数据库·mysql
手握风云-9 小时前
MySQL数据库精研之旅第十六期:深度拆解事务核心(上)
数据库·mysql
Mr. Cao code9 小时前
Docker:颠覆传统虚拟化的轻量级革命
linux·运维·ubuntu·docker·容器
Dontla9 小时前
Docker多共享网络配置策略(Docker多网络、Docker networks、Docker Compose网络、Docker网络、Docker共享网络)
网络·docker·容器