MySQL——主从同步

提醒:进行配置时,需要确保一主两从的操作系统、MySQL版本一致,否则将出现问题

环境介绍

服务器 IP
主服务器 172.25.254.10
从服务器-1 172.25.254.11
从服务器-2 172.25.254.12

配置

bash 复制代码
# 快速配置,选择多重执行,确保版本一致
[root@localhost ~]# yum install mysql-server -y
# 默认开启binlog日志

主库操作

bash 复制代码
# 主配置文件
[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

从服务器

bash 复制代码
# 从服务器设置不重复的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 时,从服务器配置成功

验证

bash 复制代码
# 在主服务器中,添加一些数据
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.

原因:密码插件导致的

方案一:修改主服务器的密码加密方式

bash 复制代码
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参数

相关推荐
Database_Cool_12 分钟前
云原生多租户隔离 + 近实时分析怎么选型?阿里云 AnalyticDB MySQL 资源隔离方案
数据库·mysql·阿里云
Database_Cool_11 小时前
Hudi 湖仓一体架构:阿里云 AnalyticDB MySQL 原生集成最佳实践
数据库·mysql·阿里云
_qingche12 小时前
H2 数据库到 MySQL 数据迁移
java·数据库·spring boot·mysql·spring·重构·kotlin
AOwhisky12 小时前
MySQL 学习笔记(第一期):数据库基础与 MySQL 初探
运维·数据库·笔记·学习·mysql·云计算
数据库小学妹13 小时前
MySQL ORDER BY 深度解析:Using temporary 与 Using filesort 的底层机制及索引优化实战
数据库·经验分享·mysql·性能优化·dba
可乐ea13 小时前
【知识获取与分享社区项目 | 项目日记第 21 天】索引构建与联想建议:Outbox 增量更新 + Completion Suggester
java·大数据·mysql·elasticsearch·搜索引擎
AI人工智能+电脑小能手13 小时前
【大白话说Java面试题 第93题】【Mysql篇】第23题:从查找速度来看,聚集索引和非聚集索引哪个更快?
java·开发语言·数据库·mysql·面试
流星白龙17 小时前
【MySQL高阶】20.InnoDB 磁盘文件
android·mysql·adb
AOwhisky17 小时前
学习自测(MySQL系列第一期、第二期)
linux·运维·数据库·学习·mysql·云计算