Mysql 主从数据同步 实现步骤

时间:2024-03-24 22:21:26

mysql版本 5.7.28

1.修改主库的my.cnf文件

vi /etc/my.cnf
Mysql 主从数据同步 实现步骤

2.登录主库mysql终端,给需要同步的从库赋权限:

Mysql 主从数据同步 实现步骤

3.从库修改my.cnf配置文件(主要是server-id要不一样,然后可以设置成只读的权限)

Mysql 主从数据同步 实现步骤

4.登录到从库mysql终端,执行命令同步主库,注意要启动 slave

mysql> change master to master_host='192.168.159.159',master_port=3306,master_user='root',master_password='root',master_log_file='mysqsql-bin.000001',master_log_pos=869;

mysql> start slave;

//查看下状态,没有异常就是配置成功了。
mysql> show slave status \G;
 

注意:配置完成,在从库客户端通过指令,出现这样的异常信息 ,  Last_IO_Error: 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 主从数据同步 实现步骤

这是由于主库和从库的auto.cnf中的server-uuid是一样的原因(回忆之前自己克隆虚拟机的时候,是带着mysql一起克隆的,所以会出现这个问题)

查看 auto.conf:

[[email protected]~]# vim /var/lib/mysql/auto.cnf

[auto]
server-uuid=4f37a731-9b79-11e8-8013-000c29f0700f

解决方案:

停止从库的mysqld服务,删除他的auto.cnf文件,再启动数据库服务即可:

[[email protected]]# systemctl stop mysqld.service

[[email protected] mysql]# mv /var/lib/mysql/auto.cnf /var/lib/mysql/auto.cnf.bak

[[email protected]]# systemctl start mysqld.service

此时再去查看从库auto.cnf,已自动生成新的server-uuid:

[[email protected] mysql]# vim /var/lib/mysql/auto.cnf


[auto]
server-uuid=2682888d-994a-11e8-aaf0-000c298cdafc

再次通过指令查看:

Mysql 主从数据同步 实现步骤

之前的异常信息没有了,问题得以解决。