快捷搜索:  汽车  科技

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work.这里笔者使用可视化工具Navicat ,读者也可以使用其他工具,只是一个简单的测试。server-id=3 relay-log=slave-02-relay-bin relay-log-index=slave-02-relay-bin.index 重启systemctl restart mysqld.service # 查看状态 systemctl status mysqld.service 配置主从关联主机配置 登录主机mysql控制台,创建用户,授权并刷新。mysql -u root -p CREATE USER

当前环境
Centos 7.6
Mysql 5.7

思路

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器(1)

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器(2)

主机配置修改conf

vim /etc/my.cnf

在 [mysqld] 后面换行追加配置,保存并退出

server-id=1 log-bin=master-bin log-bin-index=master-bin.index 重启

systemctl restart mysqld.service # 查看状态 systemctl status mysqld.service 检验

mysql -u root -p SHOW MASTER STATUS;

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器(3)

从机1配置修改conf

vim /etc/my.cnf

在 [mysqld] 后面换行追加配置,保存并退出

server-id=2 relay-log=slave-01-relay-bin relay-log-index=slave-01-relay-bin.index 重启

systemctl restart mysqld.service # 查看状态 systemctl status mysqld.service 从机2配置修改conf

vim /etc/my.cnf

在 [mysqld] 后面换行追加配置,保存并退出

server-id=3 relay-log=slave-02-relay-bin relay-log-index=slave-02-relay-bin.index 重启

systemctl restart mysqld.service # 查看状态 systemctl status mysqld.service 配置主从关联主机配置

登录主机mysql控制台,创建用户,授权并刷新。

mysql -u root -p CREATE USER 'repl'@'%' IDENTIFIED BY 'Mysql57*'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%' IDENTIFIED BY 'Mysql57*'; flush privileges;

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器(4)

从机配置

mysql -u root -p # 这里我的主机IP是192.168.1.8 change master to master_host='192.168.1.8' master_port=3306 master_user='repl' master_password='Mysql57*' master_log_file='master-bin.000001' master_log_pos=0; start slave; #停止主从同步 #stop slave; # \G 表示换行查看 show slave status \G;

若查看主从状态提示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主从数据库的配置过程:MySQL配置主从服务器(5)

测试数据同步

这里笔者使用可视化工具Navicat ,读者也可以使用其他工具,只是一个简单的测试。

  • 在主库中新增库 test-for-repl,查看从库01、02是否有库新增
  • 在主库 test-for-repl 新增表 test-create-table ,查看从库01、02对于库中是否有表新增
  • 在主库 test-for-repl 表 test-create-table ,查看从库01、02对于位置是否有数据

详细阐述mysql主从数据库的配置过程:MySQL配置主从服务器(6)

常见问题从机查看主从同步状态show slave status \G; 时报错

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主从数据库的配置过程:MySQL配置主从服务器(7)

原因

这里笔者使用了 VMware 软件创建了1个虚拟机安装 Centos7.6 MySQL5.7,然后使用该虚拟机克隆生成了另外两个虚拟机当从从库机器,导致3台虚拟机上的MySQL启动之后会生成相同的 UUID。

解决方案

找到MySQL的UUID,修改一个字符,重启服务,然后登陆MySQL控制台,开启主从

find / -name 'auto.cnf' vim /var/lib/mysql/auto.cnf systemctl restart mysqld.service mysql -u root -p start slave; # \G 表示换行查看 show slave status \G; 题外

美国“弗洛伊德”事件的影响,技术圈内开始删除诸如“master”和“slave”之类的术语,(容易让人联想到种族歧视)用“main/default/primary”和“secondary”之类的词替代。
但很多时候还是有惯性的。

猜您喜欢: