目录
- 一、主从复制的概述
 - 二、主从复制的工作原理
 - 三、搭建主从复制的结构
 - 3.1 环境准备
 - 3.2 搭建配置(主库配置)
 - 3.3 搭建配置(从库配置)
 - 3.4 测试
 

一、主从复制的概述
主从复制是指将主数据库中的DDL和DML操作的二进制文件保存到本地,然后将本地的二进制文件传递到从数据库中,从数据库重新执行二进制文件(重做),从而保证主库和从库的数据一致性。
MySQL支持一台主库向多台从库进行复制,从库也可以当做其他从数据库的主库,实现链状复制。
MySQL主从复制的优点:
- 当主库出现问题时,可以快速的切换到从数据库。
 - 实现读写分离,主从负责DML,从库负责DDL,降低主库压力。
 - 可以在从库中进行数据备份,以避免在备份期间影响主库服务。
 
主库叫做Master,从库叫做Slave
二、主从复制的工作原理

- Master主库在提交事务时(DML),会把数据变更记录在二进制日志Binlog中。
 - 从库通过IOthread读取主库中的二进制日志文件Binlog,写入到从库的中继日志Relay Log。
 - Slave通过SQLthread读取中继日志并重做日志中的事件,将改变反应到自己的数据库中。
 
三、搭建主从复制的结构
3.1 环境准备

- 开放指定端口或者直接关闭防火墙
 - 在两台电脑上都安装好MySQL数据库,并完成基础的初始化做准备工作。
 
3.2 搭建配置(主库配置)
- 修改配置文件
/etc/my.cnf 
[mysqld]
bind-address=0.0.0.0
port=3306
user=mysql
basedir=/soft/mysql
datadir=/data/mysql
socket=/tmp/mysql.sock
log-error=/data/mysql/mysql.err
pid-file=/data/mysql/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
explicit_defaults_for_timestamp=true# mysql服务器ID,保证整个集群环境中的唯一性,默认为1
server-id=1
# 是否只读 1=只读 0=读写
read-only=0
# 忽略的数据,指不需要同步的数据库
# binlog-ignore-db=mysql
# 指定同步的数据库
# binlog-do-db=db01log-bin=mysql-bin # 开启二进制日志server-uuid=85dba00a-e0ef-11e9-b341-000c29812345
 
- 重启MySQL服务器
 
systemctl restart mysqld
 
- 查看MySQL服务状态
 
systemctl status mysqld
 
- 登录MySQL,创建远程连接的账号,并赋予主从复制的权限
 
# 创建itcast用户,并设置密码,该用户可以在任意主机连接该MySQL服务
CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'root@123456';
# 为 'itcast'@'%' 分配主从复制的权限
GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
 
- 通过指令,查看二进制坐标
 
SHOW MASTER STATUS;
 
字段含义:
- file:从哪个日志文件开始推送日志
 - position:从哪个位置开始推送日志
 - binlog_ignore_db:指定不需要同步的数据库
 
3.3 搭建配置(从库配置)
- 修改配置文件
/etc/my.cnf 
# 开启二进制日志
log-bin=mysql-bin 
# mysql服务器uuid
server-uuid=6cd3023d-6ec6-11ef-a4a6-000c29bb681a
# mysql服务器ID,保证整个集群环境中的唯一性,默认为1
server-id=2
# 是否只读 1=只读 0=读写
read-only=1
# 上面的只读只能针对普通用户,如果想要针对超级管理员的话需要设置一下内容
# super-read-only=1
 
- 重启MySQL服务器
 
systemctl restart mysqld
 
- 查看MySQL服务状态
 
systemctl status mysqld
 
- 登录MySQL关联主库信息
 
CHANGE REPLICATION SOURCE TO SOURCE_HOST='XXX.XXX', SOURCE_USER='XXX', SOURCE_PASSWORD='XXX',SOURCE_LOG_FILE='XXX', SOURCE_LOG_POS='XXX';
 
上述是8.0.23中的语法。如果MySQL的版本是8.0.23之前的版本:
CHANGE MASTER TO MASTER_HOST='XXX.XXX', MASTER_USER='XXX', MASTER_PASSWORD='XXX',MASTER_LOG_FILE='XXX', MASTER_LOG_POS='XXX';
 
| 参数名 | 含义 | 8.0.23之前 | 
|---|---|---|
| SOURCE_HOST | 主库IP地址 | MASTER_HOST | 
| SOURCE_USER | 连接主库的用户名 | MASTER_USER | 
| SOURCE_PASSWORD | 连接主库的密码 | MASTER_PASSWORD | 
| SOURCE_LOG_FILE | binlog日志文件名 | MASTER_LOG_FILE | 
| SOURCE_LOG_POS | binlog日志文件位置 | MASTER_LOG_POS | 
- 开启同步操作
 
start replica; # 8.0.22之后的版本
start slave; # 8.0.22之前的版本
 
- 查看主从同步状态
 
show replica status;  # 8.0.22之后的版本
show slave status;  # 8.0.22之前的版本
 

3.4 测试
- 在主库中创建数据库创建表
 
create database db01;
user db01;
create table tb_user(id int(11) primary key not null auto_increment,name varchar(50) not null,sex varchar(1)
) engine=innodb default charset=utf8mb4;insert into tb_user(name, sex) values("Tom", "1"),("Trigger", "0"),("Dawn", "1");
 
- 在从库中查询数据,查看数据是否一致。
 
如果从库想要同步主库之前的数据,需要将主库中的数据导出为SQL脚本,在从库中执行。
 注意:主从数据库一定要配置server-id和server-uuid,并且主从数据库的id、uuid要保持唯一性
