mysql5.7主从同步配置

<强> 1。准备工作

(本文永久地址:http://woymk.blog.51cto.com/10000269/1922438)

配置环境:centos6.9, mysql5.7

先安装,配置好两台MySQL服务器

主服务器IP: 192.168.1.1

从服务器IP: 192.168.1.2

MySQL的安装请参考之前的文章:

灯环境搭建(centos6.9 + apache2.4 + mysql5.7 + php7.1)



<强> 2。配置主(主)
vi/etc/my.cnf
修改或添加下面这几行:
服务器id=1

log-bin=mysql-bin

两个可选参数(2选1):
binlog-do-db=db1 db2 #需要同步的库
binlog-ignore-db=db1 db2 #忽略不同步的库

保存后重启

/etc/init。d/mysqld重启

运行mysql客户端
mysql -uroot - p

创建同步账号

格兰特复制奴隶alt=" mysql5.7主从同步配置">

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


备份数据库

在主人上执行
, mysqldump -uroot - p db1祝辞回来。sql;

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

scp回来。sql 192.168.1.2: ~


<强> 3。配置从(奴隶)

vi/etc/my.cnf
修改或增加:
服务器id=2 #这个数值不能和主一样
可选参数(2选1,这两个参数设置成和主一样):
replicate-do-db=db1 db2
replicate-ignore-db=db1、db2

保存后重启

/etc/init。d/mysqld重启

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

在奴隶上执行
[root@slave ~] #, mysqldump -uroot - p db1 & lt;回来。sql

运行mysql客户端mysql -uroot - p

执行以下命令
停止奴隶;(根据mysql官方手册的说明,5.5之前是奴隶,5.6之后改为停止奴隶)
修改主master_host=192.168.1.1, master_user=repl, master_password=?234’, master_log_file=' mysql-bin。000001年,master_log_pos=2757;

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

开始奴隶;

查看从服务器的状态:

显示奴隶状态\ G

 mysql5.7主从同步配置


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

在主上执行
mysql>打开表;


<强> 4。验证主从复制效果

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

创建数据库test_db;

在主服务器上创建表test_tb

使用test_db;

create table test_tb (int id(3),名字char (10)),

写入一行记录

插入test_tb值(001年,“测试”);


在从服务器上查看

mysql>显示数据库;
+ - - - - - - - - - - - - - - - - - - - - - - +
| Database ,,,,,,,,,|
+ - - - - - - - - - - - - - - - - - - - - - - +
| information_schema |
| discuz ,,,,,,,,,,,|
| mysql ,,,,,,,,,,,,|
| performance_schema |
| sys ,,,,,,,,,,,,,,|
| test_db ,,,,,,,,,,|
| www ,,,,,,,,,,,,,,|
+ - - - - - - - - - - - - - - - - - - - - - - +

7行组(0.00秒)

数据库test_db已经自动创建了

mysql>select * from test_db.test_tb;
+ - - - - - - - - - - - - + +
| id ,| |名称
+ - - - - - - - - - - - - + +
|,,,1 |测试|
+ - - - - - - - - - - - - + +
1行组(0.00秒)

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


<人力资源/>


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

致命错误:奴隶I/O的线程停止,因为主人和奴隶平等mysql服务器uuid;这些uuid必须不同的复制工作。

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

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


mysql5.7主从同步配置