mysql5.7主从同步配置
admin
2023-03-24 23:01:37
0

1. 准备工作

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

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

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

主服务器IP:192.168.1.1

从服务器IP:192.168.1.2

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

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



2. 配置主(master)
vi /etc/my.cnf
修改或添加下面这几行:
server-id=1

log-bin=mysql-bin # 启用二进制日志

两个可选参数(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;

mysql5.7主从同步配置

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


备份数据库

在master上执行
mysqldump -uroot -p db1 > back.sql;

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

scp back.sql 192.168.1.2:~


3. 配置从(slave)

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

保存后重启

/etc/init.d/mysqld restart

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

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

运行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;

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

start slave;

查看从服务器的状态:

show slave status\G

mysql5.7主从同步配置


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

在主上执行
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值。


相关内容

热门资讯

玩家最新攻略“拱趴游戏有挂吗?... 玩家最新攻略“拱趴游戏有挂吗?”(原来真的有挂)您好,拱趴游戏这个游戏其实有挂的,确实是有挂的,需要...
【第一资讯】“白金岛红拐弯开挂... 【第一资讯】“白金岛红拐弯开挂神器?”(详细开挂教程)您好,白金岛红拐弯这个游戏其实有挂的,确实是有...
终于懂了“新皇豪拼三张开挂器?... 有 亲,根据资深记者爆料新皇豪拼三张是可以开挂的,确实有挂(咨询软件无需...
【今日要闻】“大宝麻将是不是有... 有 亲,根据资深记者爆料大宝麻将是可以开挂的,确实有挂(咨询软件无需打开...
玩家分享攻略“七彩丹霞究竟有挂... 有 亲,根据资深记者爆料七彩丹霞是可以开挂的,确实有挂(咨询软件无需打开...
终于懂了“樱花牛牛辅助器?”(... 有 亲,根据资深记者爆料樱花牛牛是可以开挂的,确实有挂(咨询软件无需打开...
我来教教您“新版悟空开挂神器?... 我来教教您“新版悟空开挂神器?”(透视曝光猫腻)您好,新版悟空这个游戏其实有挂的,确实是有挂的,需要...
玩家最新攻略“熊猫麻将是不是有... 您好:熊猫麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...
【第一财经】“数独大赛怎么装挂... 家人们!今天小编来为大家解答数独大赛透视挂怎么安装这个问题咨询软件客服徽9784099的挂在哪里买很...
今日重大发现“家乡亲友是不是有... 您好:家乡亲友这款游戏可以开挂,确实是有挂的,需要了解加客服微信【4282891】很多玩家在这款游戏...