当前位置: 首页 > article >正文

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;


http://www.kler.cn/a/514644.html

相关文章:

  • Autosar CP中SWC收发LIN消息的函数调用流程原理解析
  • 深入探索C#中Newtonsoft.Json库的高级进阶之路
  • 基于Redis实现短信验证码登录
  • Spring MVC:设置响应
  • NextJs - ServerAction获取文件并处理Excel
  • vscode导入模块不显示类型注解
  • Excel常用功能总结
  • java中的单元测试的使用以及原理
  • 机器学习-线性回归(简单回归、多元回归)
  • Java爬虫还有其他用途吗?
  • 头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
  • cling: c++交互式执行
  • 数据分析 基础定义
  • 深入探讨Web应用开发:从前端到后端的全栈实践
  • 无人机反制设备:察打诱一体设备技术详解
  • Linux:修改用户名
  • 5.9 洞察 OpenAI - Translator:日志(Logger)模块的 “时光记录仪”
  • 「全网最细 + 实战源码案例」设计模式——单例设计模式
  • 深度学习 Pytorch 动态计算图与梯度下降入门
  • HTTPS协议简述
  • Flask基础和URL映射
  • 【spring专题】编译spring5.3源码
  • 如何给自己的域名配置免费的HTTPS How to configure free HTTPS for your domain name
  • ERP系统的财务会计基础知识:财务管理
  • Kmeans与KMedoids聚类对比以及python实现
  • C语言中危险函数