主从复制有一主一从、一主多从、多主一从等多种模式,这里搭建一主一从模式,其他模式搭建过程的类似。

1、准备工作

  准备两台虚拟机,这里准备了两台虚拟机,并在两个节点安装MySQL。

192.168.33.55 (主节点)
192.168.33.11 (从节点)
mysql version : 8.0.31

2、主从复制搭建

2.1、在主从节点同时创建mall数据库

  

2.2、创建表

CREATE TABLE `order` (
 `id` int NOT NULL AUTO_INCREMENT COMMENT '主键',
 `price` decimal(10,2) NOT NULL COMMENT '价格',
 PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4COLLATE=utf8mb4_0900_ai_ci;

2.3、添加配置

3.3.1、主节点配置

vi /etc/my.cnf

  添加如下配置:

#在mysqld模块中添加如下配置信息
log-bin=mysql-bin #二进制文件名称
binlog-format=ROW  #二进制日志格式
server-id=53306        #服务id,各节点不能相同,一般使用ip最后一位 + 数据库端口号
binlog-do-db=mall     #同步的数据库名称
binlog-ignore-db=mysql  #忽略的数据库名称

3.3.2、从节点配置

vi /etc/my.cnf

  添加如下配置:

#在mysqld模块中添加如下配置信息
log-bin=mysql-bin       #二进制文件的名称
binlog-format=ROW       #二进制文件的格式
server-id=13306         #服务器的id

3.3.3、注意事项

  主从配置一定要添加在[mysqld]下,我第一次配置将配置内容添加在了[mysqld_safe]下,my.cnf配置的文件内容未生效,导致主从的服务id相同,丛节点出现如下错误:

  修改完配置后,重启数据库。

2.4、登录主库,创建绑定账号

  登录主数据库 mysql -u root -p

4.4.1、创建绑定用户

  登录主数据库mysql -u root -p,创建绑定用户:

--授权操作
create user 'snails'@'%' IDENTIFIED BY 'snails';
GRANT REPLICATION SLAVE ON *.* TO 'snails'@'%';
alter user 'snails'@'%' IDENTIFIED WITH mysql_native_password BY 'snails';

4.4.2、查看主库状态

show master status

   记录File和Position,在从数据库连接主数据库时需要用到。

4.4.3、登录从数据库连接主服务器

  登录从数据库 mysql -u root -p,执行连接主数据库的命令:

change master to master_host='192.168.33.55',master_user='snails',master_password='snails',master_port=3306,master_log_file='mysql-bin.000001',master_log_pos=1254;

4.4.4、启动slave

start slave;

4.4.5、查看slave状态

show slave status\G

   当IO、SQL运行为Yes时,表示主从复制配置成功。

4.4.6、验证主从复制

  在主数据库中添加记录:

    

  稍等片刻,登录从数据库,查看数据同步情况。

  

3、搭建过程中出现的问题

3.1、主从配置my.cnf未生效导致服务id重复

  执行show slave status\G,查看从库状态时出现:

Last_IO_Error: Fatal error: The slave I/O thread stops because master and slave have equal MySQL server ids; these ids must be different for replication to work (or the –replicate-same-server-id option must be used on slave but this does not always make sense; please check the manual before using it).

   在my.cnf配置文件中,主节点数据库的server-id配置为 53306,从节点数据库的server-id配置的为13304。但登录主从数据库mysql -u root -p,执行查看服务id命令:

show variables like 'server_id';

  发现无论是主节点还是从节点,server_id都为 1,my.cnf配置文件没有生效。

问题原因:

  my.cnf的配置内容写在了[mysqld_safe]标签后面,导致未生效。

解决方案:

  将配置内容设置到[mysqld]标签后,[mysqld_safe]标签前。

3.2、主库默认插件导致同步权限问题

  执行show slave status\G,查看从库状态时出现:

Last_IO_Error: error connecting to master ‘slave@192.168.33.55:3306’ – retry-time: 60 retries: 1 message: Authentication plugin ‘caching_sha2_password’ reported error: Authentication requires secure connection.

问题原因:

  主库plugin是caching_sha2_password 导致连接不上,修改为mysql_native_password即可解决。

解决方案:

  登录主数据库mysql -u root -p,执行如下命令:

alter user 'slave'@'%' IDENTIFIED WITH mysql_native_password BY 'slave';

3.3、binlog日志文件不匹配同步失败

  执行show slave status\G,查看从库状态时出现:

Last_IO_Error: Got fatal error 1236 from master when reading data from binary log: ‘Could not find first log file name in binary log index file’

 问题原因:

  日志文件读取错误,在从数据与主数据库建立关系时,master_log_file文件名称与主数据库中的文件名称不一致,导致无法读取日志文件

  从数据库与主数据库建立关系的日志名称:

  主数据库,show master status\G 的 File名称。

3.4、相同的server UUIDS问题

  执行show slave status\G,查看从库状态时出现:

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.

问题原因:

  主数据库与从数据的server UUID相同。登录主从数据库mysql -u root -p,查看uuid值:

show variables like '%server_uuid%';

解决方案:

  执行如下命令,查看auto.cnf配置文件,一般在mysql的数据文件目录中。

find -name auto.cnf

  修改auto.cnf中的uuid值使得主从数据库的uuid不同即可。