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

相关推荐
咩咩大主教3 小时前
Go语言通过Casbin配合MySQL和Gorm实现RBAC访问控制模型
mysql·golang·鉴权·go语言·rbac·abac·casbin
猿小喵6 小时前
MySQL四种隔离级别
数据库·mysql
祁思妙想7 小时前
【LeetCode】--- MySQL刷题集合
数据库·mysql
m0_748248027 小时前
【MySQL】C# 连接MySQL
数据库·mysql·c#
东软吴彦祖8 小时前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
慵懒的猫mi9 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin
码农丁丁12 小时前
为什么数据库不应该使用外键
数据库·mysql·oracle·数据库设计·外键
随心Coding14 小时前
【MySQL】存储引擎有哪些?区别是什么?
数据库·mysql
羊小猪~~17 小时前
MYSQL学习笔记(四):多表关系、多表查询(交叉连接、内连接、外连接、自连接)、七种JSONS、集合
数据库·笔记·后端·sql·学习·mysql·考研