mysql 主从复制 docker_MySQL主从复制配置(Docker容器内配置)

主从工作原理:

8b532b31d372691f3e6876c5f8c852a7.png

配置介绍:

MASTER:172.17.0.2

SLAVE:172.17.0.3

MASTER内数据库:

d2aa64d509bb53c67208c672526508ca.png

仅仅同步以上两个库(在configerdata库中创建了wu2表)

SLAVE库:

e1087f08169aaa4b67335f8c50de6754.png

空空如也

1、将MASTER库的数据库导入到SLAVE库中

(1)使用mysqldump备份MASTER库

备份前最好将服务停止,防止有数据在设置过程中写入

#将configerdata userdata两个库的结构与数据全部备份到/root/baksql.sql中

mysqldump-h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql--all-databases #备份所有的数据库--databases #备份指定库,多个库用空格隔开--database 数据库名 表1 表2 #备份指定库的表,多个表用空格隔开--database 库名 | gzip #备份库时进行压缩

mysqldump -h 127.0.0.1 -uroot -proot1 --databases configerdata userdata > /root/baksql.sql

36f78eb2b3fafa8889f46acda10a8d13.png

(2)将导出的库文件传输到SLAVE中(scp、lrzsz均可)

95946801708f2adc6c9615d6bdf17a70.png

(3)将.sql文件导入到SLAVE数据库中

进入输入库,执行:

source /root/baksql.sql

0c53f7fc65faba0a0c2323b995978e0e.png

查看SLAVE库内有无MASTER中的表

bafda20d0e2aab7dedc8bc98f33a27a1.png

ok,导入成功

2、修改MySQL配置文件使用bin-log进行同步

(1)一般在配置文件是/etc/my.cnf,我的是apt-get装,所以位置不同

vim /etc/mysql/mysql.conf.d/mysqld.cnf

在mysqld参数下添加:

log-bin = mysql-bin

server-id =1replicate-do-db=configerdata #指定同步的数据库(若需将所有数据库同步,则不需加此配置项)

replicate-do-db=userdata #指定同步的数据库

#replicate-ignore-db=mysql 此配置为指定不同步的数据库

b46a887da481d34e7f9dba4beb2d7294.png

service mysql restart #重启mysql

(2)进入MASTER mysql中,创建用于SLAVE的用户

GRANT ALL ON*.* TO liu@172.17.0.3 IDENTIFIED BY 'liu1'; #赋予liu用户所有数据库所有权限

GRANT ALL PRIVILEGES ON*.* TO fan@172.17.0.3 IDENTIFIED BY 'fan1'; #在SLAVE中创建在MASTER有所有特殊权限的用户

FLUSH PRIVILEGES; #刷新权限

71ed8b82d841f2aa7f28a740028e6606.png

(3)前往SLAVE主机测试登录刚刚创建的用户

a3fe0490f13b67075820efa0e796a5ac.png

显示无法连接,但是网是通的

问题在于MASTER配置文件中限制了其他主机登录,修改以下配置重启即可:

2f0d23fe84b8df4f3656033dd18c0f2e.png

现在连接:

3fc881c7a57f1e70c2fe566e0ada4e52.png

ok,连接成功

3、从节点配置访问主节点的参数信息

(1)首先编辑从机配置文件,添加如下配置:

server-id=2

b09c41047b227aa7c3c01086c51877c0.png

service mysql restart #重启mysql

(2)赋予权限

查看主服务器的节点

show master status\G;

cbfcf8fe4e60d3a7156761fe8faaecc6.png

在从服务中配置:

首先关闭SLAVE线程;STOP SLAVE;

然后再执行:

CHANGE MASTER TO MASTER_HOST='172.17.0.2',MASTER_USER='fan',MASTER_PASSWORD='fan1', MASTER_LOG_FILE='mysql-bin.000002',MASTER_LOG_POS=594;

特别注意:MASTER_LOG_FILE= 、MASTER_LOG_POS=必须和MASTER一致

ebf54c43b8ba5b6958e398c07c39380b.png

查看SLAVE状态,已经同步成功

26019668df41d40d453c31beb289f215.png

开启SLAVE线程:

137eb038c8b28c7dd3454a6380c2bd2d.png

4、测试数据是否同步

在MASTER中添加数据

ea75077ddd317b5bcb7a3f3f47df3b9c.png

进SLAVE库中查有无同步

eb5d735430b8839206573238e32c5bbd.png

ok,已同步。

如有转载请标明出处 谢谢

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值