MySQL——主从同步
提醒:进行配置时,需要确保一主两从的操作系统、MySQL版本一致,否则将出现问题
环境介绍
服务器 | IP |
---|---|
主服务器 | 172.25.254.10 |
从服务器-1 | 172.25.254.11 |
从服务器-2 | 172.25.254.12 |
配置
# 快速配置,选择多重执行,确保版本一致
[root@localhost ~]# yum install mysql-server -y
# 默认开启binlog日志
主库操作
# 主配置文件
[root@localhost ~]# vim /etc/my.cnf
# 子配置文件(二选一配置)
[root@localhost ~]# vim /etc/my.cnf.d/mysql-server.cnf
# 设置server_id(要求唯一)
server_id=10
# 启动服务
[root@localhost ~]# systemctl enable --now mysqld
# 默认无密码
[root@localhost ~]# mysql -u root -p
# 创建同步用账户
CREATE USER 'xxx'@'172.25.254.%' IDENTIFIED BY 'aaa';
# 对账户开放同步权限
GRANT REPLICATION SLAVE ON *.* TO 'xxx'@'172.25.254.%';
# 查看主服务器状态(关注MASTER_LOG_FILE、MASTER_LOG_POS)
SHOW MASTER STATUS\G
# 记录MASTER_LOG_FILE=binlog.000001、MASTER_LOG_POS=710
从服务器
# 从服务器设置不重复的server_id
# 从服务器-1——server_id=11
# 从服务器-2——server_id=12
# 启动服务
[root@localhost ~]# systemctl enable --now mysqld
# 默认无密码
[root@localhost ~]# mysql -u root -p
# 主从设置
mysql> CHANGE MASTER TO
# 主服务器IP
-> MASTER_HOST='172.25.254.10',
# 主从同步账户
-> MASTER_USER='xxx',
# 主从账户密码
-> MASTER_PASSWORD='aaa',
# 主服务器的binlog日志
-> MASTER_LOG_FILE='binlog.000001',
# 主服务器的Position
-> MASTER_LOG_POS=710,
# 解决密码插件报错
-> get_master_public_key=1;
# 当错误配置时,先stop slave再再进行配置
mysql> start slave;
# 查看从服务器状态
mysql> SHOW SLAVE STATUS\G
当显示 Slave_IO_Running: Yes、 Slave_SQL_Running: Yes 时,从服务器配置成功
验证
# 在主服务器中,添加一些数据
mysql> CREATE DATABASE ovo;
mysql> CREATE TABLE ovo.userlist (
-> username varchar(20) not null,
-> password varchar(50) not null);
mysql> INSERT INTO ovo.userlist VALUE ('ovo','111');
# 在从服务器中,查看是否有名为 ovo 的数据库
# 以及数据库内是否有 username:ovo password:111 的数据
主从同步原理
在主从同步过程中,会基于多个线程来操作(主库线程以及从库线程)
二进制日志转储线程(Binlog dump thread)是一个主库线程
当从库线程连接的时候, 主库可以将二进制日志发送给从库
主库读取事件的时候,会在 Binlog 上加锁,读取完成之后,再将锁释放掉
从库 I/O 线程
会连接到主库,向主库发送请求更新 Binlog
从库的 I/O 线程
就可以读取到Dump线程
发送的 Binlog 更新部分,并且拷贝到本地的中继日志 (Relay log)
从库 SQL 线程
会读取从库中的中继日志,并且执行日志中的事件,使得从库中的数据与主库保持同步
遇到的问题
描述:从服务器的Slave_IO_Running
一直处于Connecting
状态
报错:Message: Authentication plugin ‘caching_sha2_password’ reported error: Authentication requires secure connection.
原因:密码插件导致的
方案一:修改主服务器的密码加密方式
ALTER USER 'xxx'@'172.25.254.%' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD by 'aaa';
方案二:主从设置时,添加get_master_public_key=1;
参数(文章采用此方法)
描述:从服务器的Slave_IO_Running
处于No
状态
报错:‘Could not find first log file name in binary log index file’
原因:从服务器MASTER_LOG_FILE
配置错误,与主服务器的binlog不一致
方案:修改主从设置的MASTER_LOG_FILE
参数