首页 > 代码库 > MySQL主从复制

MySQL主从复制

  1. 两台机器,192.168.162.128(主) 192.168.162.130(从)

  2. 配置主的配置文件

    vi /etc/my.cnf

    技术分享

  3. 创建复制用户并授权给从服务器

    grant replication slave on *.* to ‘rpl‘@‘192.168.162.130‘ identified by ‘123456‘;


  4. 重启主服务器的MySQL  /etc/init.d/mysqld restart

  5. 查看master信息: 进入MySQL  show master status \G;

      技术分享

  6. 修改从库配置文件

    vi /etc/my.cnf

    技术分享

  7. 重启从服务器MySQL,进入MySQL

  8. 指定主服务器IP等信息

     change master to master_host=‘192.168.162.128 ‘,master_user=‘rpl‘,master_password=‘123456‘,master_log_file=‘mysql-bin.000001‘,master_log_pos=647;

  9. 启动slave  :start slave;

  10. 查看slave状态: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

技术分享

意思是主和从必须都要有不同的uuid,我们分别去查看下主从的uuid

主:server-uuid=4e6c5a78-1e9a-11e7-8c65-000c29426312

技术分享

查看从库uuid  从库uuid:server-uuid=4e6c5a78-1e9a-11e7-8c65-000c29426312

技术分享

可以看出是真的一样,原因在于 我是先安装了一个虚拟机并装好MySQL,后面有复制了一遍,作为从服务器,所以导致了这个UUID是一样的。

接下来就是解决这个UUID问题,将从库上的auto.cnf 备份下。然后重启从库。再看下从库的UUID

[auto]

server-uuid=2e9c834a-1eb2-11e7-864b-000c2928472e

技术分享

再次查看从库状态

技术分享

从库状态正常了

11.测试主从是否正常

  主库上创建一个测试库,test :create database test;

  创建测试表:

create table test.test(

id int,

username varchar(10)

)ENGINE=‘innodb‘

12.查看从库: 

技术分享

正常,说明主从搭建成功


MySQL主从复制