docker mysql 同步_docker mySql主从同步

这里使用mysql5.6.

docker pull mysql:5.6

在根目录下创建mysql_1.cnf:

主库配置

[mysqld]

log-bin=mysql-bin

server-id=1

在根目录下创建mysql_2.cnf:

从库配置

[mysqld]

log-bin=mysql-bin

server-id=2

root 密码为123456

docker run --name mysql_1 -v /root/mysql_1.cnf:/etc/mysql/my.cnf -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6

docker exec -it mysql_1 /bin/bash

docker run --name mysql_2 -v /root/mysql_2.cnf:/etc/mysql/my.cnf -p 3308:3306 -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.6

docker exec -it mysql_2 /bin/bash

在主库中创建一个sync用户。

create user 'sync'@'%' identified by '123';

主库中执行

grant all privileges on *.* to 'sync'@'%' identified by '123456' with grant option;

flush privileges;

这里的logfile字段从库中master_log_file会用到。

show master status;

查看docker容器的ip

docker inspect --format '{{.NetworkSettings.IPAddress}}' mysql_1

docker inspect --format '{{.NetworkSettings.IPAddress}}' mysql_2

从库中执行

stop slave;

host为主库的ip user为主库中创建的 logfile为主库中status语句结果中的file

change master to master_host='172.17.0.3', master_user='sync', master_password='123456', master_log_file='mysql-bin.000004';

start slave;

show slave status;

当Slave_IO_Running Slave_SQL_Running 都为 Yes 成功

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值