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

2、基于gtid的主从同步配置

主从服务器 都开启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;

相关推荐
计算机毕设指导61 小时前
基于SpringBoot的城乡商城协作系统【附源码】
java·spring boot·后端·mysql·spring·tomcat·maven
橘猫云计算机设计1 小时前
基于Django的购物商城平台的设计与实现(源码+lw+部署文档+讲解),源码可白嫖!
java·数据库·spring boot·后端·django
2501_903238651 小时前
Spring Boot日志配置与环境切换实战
数据库·spring boot·后端·个人开发
梓沂1 小时前
审计级别未启用扩展模式导致查询 DBA_AUDIT_TRAIL 时 SQL_TEXT 列为空
数据库·sql·dba
Smile丶凉轩2 小时前
数据库面试知识点总结
数据库·c++·mysql
RainbowSea3 小时前
9-1. MySQL 性能分析工具的使用——last\_query\_cost,慢查询日志
数据库·sql·mysql
Sui_Network3 小时前
Sui 如何支持各种类型的 Web3 游戏
大数据·数据库·人工智能·游戏·web3·区块链
猿java3 小时前
很多程序员会忽略的问题:创建 MySQL索引,需要注意什么?
java·后端·mysql
ZKNOW甄知科技3 小时前
IT服务运营管理体系的常用方法论与实践指南(上)
大数据·数据库·人工智能
黄雪超5 小时前
深入HBase——核心组件
数据结构·数据库·hbase