Centos7的Docker中搭建MySQL主从节点

1. 拉取MySQL镜像

2. 创建文件夹和配置文件

创建文件夹:

mkdir /docker/mysql-master/cnf
mkdir /docker/mysql-master/data
mkdir /docker/mysql-master/log

mkdir /docker/mysql-slave/cnf
mkdir /docker/mysql-slave/data
mkdir /docker/mysql-slave/log

/docker/mysql-master/cnf 文件夹 创建 mysql.cnf 文件:

[mysqld]
## 设置server_id,注意要在同一局域网内唯一
server-id=1
## 开启binlog
log-bin=mysql-bin
## binlog缓存
binlog_cache_size=1M
## binlog格式(mixed、statement、row,默认格式是statement)
binlog_format=mixed

 /docker/mysql-slave/cnf 文件夹 创建 mysql.cnf 文件:

[mysqld]
## 设置server_id,注意要唯一
server-id=2
## 开启binlog,以备Slave作为其它Slave的Master时使用
log-bin=mysql-slave-bin
## relay_log配置中继日志
relay_log=edu-mysql-relay-bin
## 如果需要同步函数或者存储过程
log_bin_trust_function_creators=true
## binlog缓存
binlog_cache_size=1M
## binlog格式(mixed、statement、row,默认格式是statement)
binlog_format=mixed
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免slave端复制中断
## 如:1062错误是指一些主键重复,1032错误是因为主从数据库数据不一致
slave_skip_errors=1062   ## 跳过主从复制中遇到的错误,可配可不配
read-only=1 #1只读,0读写

3. 启动容器

# master 主服务器:
docker run -itd \
	--name mysql-master \
	-p 3307:3306 \
	-e MYSQL_ROOT_PASSWORD=root \
	-v /docker/mysql-master/cnf:/etc/mysql/conf.d \
	-v /docker/mysql-master/data:/var/lib/mysql \
	-v /docker/mysql-master/log:/var/log \
	--restart always \
	mysql

# slave 从服务器
docker run -itd \
	--name mysql-slave \
	-p 3308:3306 \
	-e MYSQL_ROOT_PASSWORD=root \
	-v /docker/mysql-slave/cnf:/etc/mysql/conf.d \
	-v /docker/mysql-slave/data:/var/lib/mysql \
	-v /docker/mysql-slave/log:/var/log \
	--restart always \
	mysql

4. 配置主从

主节点

# 进入到docker容器
docker exec -it mysql-master /bin/bash
 
# 登录到mysql服务 回车后输入密码
mysql -uroot -proot


# 执行下面两条命令  最好主库和从库都修改一下
alter user 'root'@'localhost' identified with mysql_native_password by 'root';
alter user 'root'@'%' identified with mysql_native_password by 'root';

flush privileges;
SHOW BINARY LOG STATUS;

 (待会有用)

从节点

# 进入slave 从数据库容器
docker exec -it mysql-slave /bin/bash
 
#进入容器后 登录mysql控制台
mysql -uroot -proot

 下面的选择一条执行即可,8.0版本以上的执行第一条

# mysql 8.0 以上版本需要下面这种命令
CHANGE REPLICATION SOURCE TO SOURCE_HOST='192.168.111.129', SOURCE_LOG_FILE='mysql-bin.000003', SOURCE_LOG_POS=912, SOURCE_PORT=3307, SOURCE_USER='root', SOURCE_PASSWORD='root';
 
# mysql 8.0 以下版本请使用 如下命令 否则会报sql语法错误
change master to master_host='192.168.111.129', master_user='root', master_password='root', master_port=3307, master_log_file='mysql-bin.000003', master_log_pos=912, master_connect_retry=30;

开启: 

START SLAVE;

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值