MySQL主从配置

一、 主从原理

MySQL 主从同步是一种数据库复制技术,它通过将主服务器上的数据更改复制到一个或多个从服务器,实现数据的自动同步。主从同步的核心原理是将主服务器上的二进制日志复制到从服务器,并在从服务器上执行这些日志中的操作。

二、主从复制的工作流程

主数据库记录写操作到 二进制日志。

从数据库 的 I/O 线程 连接主数据库,读取主库的二进制日志,并存储到 中继日志。

SQL 线程 从中继日志中读取事件,并将事件执行到从库中。

三、进行主从配置

1、基于binlog的主从同步配置

主库配置:

root@server \~\]# yum install mysql-server -y \[root@server \~\]# vim /etc/my.cnf (或者子配置文件:/etc/my.cnf.d/mysql-server.cnf) server_id=1 (服务id可以随便配置,一般可根据ip) \[root@server \~\]# systemctl restart mysqld # 创建用于复制的用户并赋予权限 mysql\>create user 'req'@'192.168.8.% identified with mysql_native_password by '123456'; 加上with mysql_native_password 是为了兼容之前的密码插件,可以不加 mysql\> grant replication slave on \*.\* to rep@'192.168.8.%'; mysql\> show master status; #获取主服务器的二进制日志文件名和位置: +---------------+----------+--------------+------------------+-------------------+ \| File \| Position \| Binlog_Do_DB \| Binlog_Ignore_DB \| Executed_Gtid_Set \| +---------------+----------+--------------+------------------+-------------------+ \| binlog.000001 \| 1054 \| \| \| \| +---------------+----------+--------------+------------------+-------------------+ 1 row in set (0.00 sec) **从库配置:** \[root@slave1 \~\]# yum install mysql-server -y \[root@slave1 \~\]# vim /etc/my.cnf server_id=2 \[root@slave1 \~\]# systemctl restart mysqld \[root@slave1 \~\]# mysql mysql\> change master to -\> master_host='192.168.8.128', ----主库ip -\> master_user='rep', ----之前授权的用户 -\> master_password='123456', -\> master_log_file='binlog.000001', ----主服务器的二进制日志文件名 -\> master_log_pos=1054; ---- 主服务器的二进制日志位置 mysql\> start slave; mysql\> show slave status \\G ![](https://i-blog.csdnimg.cn/direct/9c8fae868e394a1c8d4e072466bca012.png)

主从服务器 都开启gtid:

在/etc/my.cnf的server_id下面加入两行,然后重启服务:

gtid_mode=ON
enforce-gtid-consistency=ON

从库配置:

mysql> stop slave;#停止复制线程


mysql> change master to
-> master_host='192.168.8.138',
-> master_port=3306,
-> master_user='rep',
-> master_password='123456',
-> master_auto_position=1;

Query OK, 0 rows affected, 8 warnings (0.00 sec)

mysql> start slave;

相关推荐
Re.不晚16 分钟前
MySQL进阶之战——索引、事务与锁、高可用架构的三重奏
数据库·mysql·架构
老邓计算机毕设25 分钟前
SSM智慧社区信息化服务平台4v5hv(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·智慧社区、·信息化平台
麦聪聊数据1 小时前
为何通用堡垒机无法在数据库运维中实现精准风控?
数据库·sql·安全·低代码·架构
2301_790300961 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
m0_736919101 小时前
用Pandas处理时间序列数据(Time Series)
jvm·数据库·python
亓才孓1 小时前
[JDBC]PreparedStatement替代Statement
java·数据库
m0_466525292 小时前
绿盟科技风云卫AI安全能力平台成果重磅发布
大数据·数据库·人工智能·安全
爱学习的阿磊2 小时前
使用Fabric自动化你的部署流程
jvm·数据库·python
枷锁—sha2 小时前
【SRC】SQL注入快速判定与应对策略(一)
网络·数据库·sql·安全·网络安全·系统安全
惜分飞2 小时前
ORA-600 kcratr_nab_less_than_odr和ORA-600 4193故障处理--惜分飞
数据库·oracle