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参数

相关推荐
u***324321 分钟前
【MySQL】数据库和表的操作
数据库·mysql·oracle
好奇的菜鸟26 分钟前
MySQL 8 开启远程登录
数据库·mysql·adb
是2的10次方啊1 小时前
MySQL索引设计原则:明明建了索引为什么还是慢?7条实战原则帮你避坑
mysql
('-')1 小时前
《从根上理解MySQL是怎样运行的》第十二章学习笔记
笔记·学习·mysql
深瞳智检2 小时前
学习应用 第001期-Windows 10 用 CMD 安装 MySQL 全流程解析(免安装版)
数据库·windows·mysql·压缩包·环境安装
华纳云IDC服务商2 小时前
MySQL数据库如何防止SQL注入攻击
数据库·sql·mysql
h***59333 小时前
使用Canal将MySQL数据同步到ES(Linux)
linux·mysql·elasticsearch
P***84393 小时前
【MySQL】C# 连接MySQL
数据库·mysql·c#
n***26563 小时前
MySQL JSON数据类型全解析(JSON datatype and functions)
android·mysql·json
o***74173 小时前
MySQL root用户密码忘记怎么办(Reset root account password)
数据库·mysql·adb