mysql5.7.25主从同步配置_mysql5.7主从同步配置

两个可选参数(2选1):

binlog-do-db=db1,db2 #需要同步的库

binlog-ignore-db=db1,db2 #忽略不同步的库

保存后重启

/etc/init.d/mysqld restart

运行mysql客户端

mysql -uroot -p

创建同步账号

grant replication slave on *.* to ‘repl‘@‘192.168.1.2‘ identified by ‘1234‘;

flush privileges;

锁表,不让数据写入

flush tables with read lock;

show master status;

b5ed023e119c7c1bb378b1fe91069ce5.png

记录下二进制日志文件名和位置

备份数据库

在master上执行

mysqldump -uroot -p db1 > back.sql;

把备份好的数据拷贝到从服务器

scp back.sql 192.168.1.2:~

3. 配置从(slave)

把主服务器备份的数据导入从服务器

在slave上执行

[root@slave ~]# mysqldump -uroot -p db1 < back.sql

vi /etc/my.cnf

修改或增加:

server-id=2 #这个数值不能和主一样

可选参数(2选1,这两个参数设置成和主一样):

replicate-do-db=db1,db2

replicate-ignore-db=db1,db2

service mysqld restart

运行mysql客户端

mysql -uroot -p

执行以下命令

stop slave; (根据mysql官方手册的说明,5.5之前是slave stop,5.6之后改为stop slave)

change master to master_host=‘192.168.1.1‘, master_user=‘repl‘, master_password=‘1234‘,master_log_file=‘mysql-bin.000001‘, master_log_pos=2757;

start slave; (master_log_file和master_log_pos填上刚才记录下的二进制日志文件名和位置)

查看从的状态: show slave status\G

4aaf2f2a2720fad8c9c4ef8719f285d5.png

完成后取消主服务器数据库的锁定

在主上执行

mysql> unlock tables

4. 验证主从复制效果

在主服务器上创建数据库test_db

create database test_db;

在主服务器上创建表test_tb

use test_db;

create table test_tb(id int(3),name char(10));

写入一行记录

insert into test_tb values(001,"test");

在从服务器上查看

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| discuz             |

| mysql              |

| performance_schema |

| sys                |

| test_db            |

| www                |

+--------------------+

7 rows in set (0.00 sec)

数据库test_db已经自动创建了

mysql> select * from test_db.test_tb;

+------+------+

| id   | name |

+------+------+

|    1 | test |

+------+------+

1 row in set (0.00 sec)

表里的数据也已经自动复制过来了,说明主从同步配置成功。

配置mysql主从时,如果显示下列错误:

Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.

这是因为mysql是克隆过来的,或者拷贝整个data目录时把auto.cnf文件也拷贝过来了,导致主从mysql uuid相同, Slave_IO无法启动。

解决办法:修改mysql data 目录下auto.cnf 文件中uuid的值,或者删除auto.cnf文件后重启mysql服务让它自动生成新的uuid值。

mysql5.7主从同步配置

标签:mysql主从同步

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉

本文系统来源:http://woymk.blog.51cto.com/10000269/1922438

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值