MySQL数据库主从集群架构搭建

article/2025/11/10 10:36:29

一、相关概念

二、配置一主一从

三、配置一主多从

四、配置主从从

五、配置主主结构

六、配置半同步复制模式

一、相关概念

1.1 主从同步介绍:

  • 存储数据的服务结构,分为2种角色:

  • 主服务器(master):接受客户端访问连接

  • 从服务器(slave):自动同步主服务器数据

1.2主从同步工作原理:

  • 主服务器:启用binlog日志

  • 从服务器:

  • IO线程:复制master主机binlog日志文件里的SQL命令保存到中继日志文件里。

  • SQL线程:执行中继日志文件里的SQL语句,实现与Master数据一致。

1.3常用的主从同步结构:

  1. 一主一从结构

  1. 一主多从结构

  1. 主从从结构

  1. 主主结构

1.4 配置步骤:

配置master服务器

      1 启用binlog日志

      2 用户授权

      3 查看日志信息

配置slave服务器

      1指定server_id 并重启mysqld 服务

      2 指定主服务器信息(如果数据不一样,要先确保数据一致)

      3启动slave进程

      4查看状态信息

二、配置一主一从同步结构

     服务器说明:

            master1 (主服务器)

            slave1 (从服务器)

     第一步配置master1(主)服务器,具体操作如下:

打开MySQL配置文件

写明serverID和开启binlog日志保存退出

重启MySQL服务

管理员用户登陆数据库

添加用户授权

查看到的日志名和偏移量是给从服务器使用的

第二步配置slave1(从)服务器 :

打开数据库配置文件

指定serverID (主从结构中serverID不能重复)

重启MySQL服务

管理员登陆数据库

日志名和偏移量按照自己的主服务器值输入

启动slave进程

查看slave状态,IO和SQL线程都是yes状态就可以

三 配置一主多从同步结构

 服务器说明:

        master1 (主服务器)

        slave1 (从服务器)

        slave2 (从服务器)

在一主一从的结构基础上加一台MySQL服务器(slave2)

配置slave2:

打开slave2配置文件

指定serverID(不与之前主从结构ID重复)

重启slave2的MySQL服务

把master1的库做完全备份拷贝给slave2

slave2使用备份文件恢复数据并在备份文件里查看日志名和偏移量

管理员登陆slave2的数据库

使用并在备份文件里查看到的日志名和偏移量

启用slave进程

查看slave状态,slave2的IO线程和SQL线程都是yes    一主多从就搭建好了

四、配置主从从同步结构

     主从从结构: 给一主一从结构中的从服务器也配置从服务器

     服务器说明:

           master1 (第一个主服务器)

           ms1 (master的从服务器,slave1的主服务器)

           slave1 (ms1的从服务器)

配置master1:

打开master1的MySQL配置文件

指定serverID并开启binlog日志

重启MySQL服务

管理员登陆server1的数据库

添加用户授权

查看日志信息和偏移量

配置ms1:

打开MySQL配置文件

指定serverID,打开binlog日志并且允许级联复制

重启数据库服务并用管理员登陆数据库

使用master1查看的日志名和偏移量

启用slave进程并查看slave状态(IO线程和SQL线程状态必须都为yes)

添加用户授权

查看日志名和偏移量

配置slave1:

打开MySQL配置文件

指定serverID 

重启数据库服务并用管理员登陆数据库

指定ms1的日志名和偏移量以及IP地址

打开slave进程并且查看slave状态(IO线程和SQL线程的状态)

五、配置主主同步结构

        主主结构也叫互为主从。

 服务器介绍:

          ms1 (ms2的主,同为ms2的从)

          ms2 (ms1的从,同为ms1的主)

配置ms1和ms2(相同配置。serverID,IP地址,日志名,偏移量不一致):

打开MySQL配置文件

指定serverID并打开binlog日志 (ms2换成52即可)

重启数据库服务,管理员用户登陆数据库

添加用户授权

查看日志名和偏移量

指定另一个服务器的IP,日志名,偏移量

打开slave进程,查看slave状态(IO线程和SQL线程状态)

六、配置主从同步复制数据工作模式

支持的工作方式:

第1种 异步复制模式(默认)

主服务器执行完一次事务后,立即将结果返给客户端,

不关心从服务器是否已经同步数据。

第2种 半同步复制模式

主服务器在执行完一次事务后,等待至少一台从服务器同步数据完成,

才将结果返回给客户端。

永久配置编辑主配置文件:

打开mysql配置文件

在配置文件添加“配置模块”和“启用模块”

重启数据库服务,管理员登录

模糊匹配,查看到模块是启用状态即可


http://chatgpt.dhexx.cn/article/ORoYmBQX.shtml

相关文章

谈谈mysql数据库集群

现在,随着上网人数的激增,一些大型的网站开始使用数据库集群来提高数据库的可靠性和数据库的性能。那么在介绍数据库集群之前首先需要弄清楚几个问题。 1.为什么要用数据库集群 (1)通过使用数据库集群可以使读写分离,提…

MySQL集群配置

1. MySQL集群简介 MySQL Cluster 是MySQL适合于分布式计算环境的高实用、高冗余版本。它采用了NDB Cluster 存储引擎,允许在1个 Cluster 中运行多个MySQL服务器。MySQL Cluster 是一种技术,该技术允许在无共享的系统中部署“内存中”数据库的 Cluster 。…

MySQL数据库集群(双主双从)

文章目录 MySQL数据库集群(双主双从)实验环境双主双从双主双从进行测试 MySQL数据库集群(双主双从) 实验环境 保证每台centos7服务器配置静态的IP,初始化服务器,关闭防火前和selinux,保证四台服务器之间可以互相通信,并且做好hosts域名解析…

数据库与集群

数据库与集群 1、数据库集群 概念:数据库集群,顾名思义,就是利用至少两台或者多台数据库服务器,构成一个虚拟单一数据库逻辑映像,像单数据库系统那样,向客户端提供透明的数据服务。 数据库集群两个关键定…

数据库-mysql集群方案总结

一 概念解读 1 数据库高可用 高可用指的是:如果数据库发生了宕机或者意外中断等故障,能尽快恢复数据库的 可用性,保证业务不会因为数据库的故障而中断。 另外,数据库高可用还要数据一致性,如下: (1) 用作备份、只读副…

数据库集群

目录 主从复制集群单机数据库的问题单机到集群主从复制传统主从复制异步复制半同步复制 组复制(MGR MySQL Group Replication MGR ) 主从复制演示准备两个MySQL服务实例修改主数据库MySQL_A的my.ini中的[mysqld]配置项下的配置如下修改从数据库MySQL_B的…

MySQL数据库的集群方案

1.简介 我们一般应用对数据库而言都是“读多写少”,也就说对数据库读取数据的压力比较大,有一个思路就是说采用数据库集群的方案: 其中一个是主库,负责写入数据,我们称之为:写库; 其它都是从库&…

MySQL集群解决方案(1):MySQL数据库的集群方案

1、系统架构存在的问题 在我们的系统架构中,DBserver方面我们只是使用了单节点服务,如果面对大并发,海量数据的存储,显然单节点的系统架构将存在很严重的问题,所以接下来,我们将实现MySQL的集群&#xff0c…

C语言回调函数详解及实例

C语言回调函数详解及实例 回调函数:函数 F1 调用函数 F2 的时候,函数 F1 通过参数给函数 F2 传递了另外一个函数 F3 的指针,在函数 F2 执行的过程中,函数F2 调用了函数 F3,这个动作就叫做回调(Callback&…

回调函数

什么是回调函数? 有以下三点 1、自己创建的函数; 2、没有调用; 3、但是函数执行了(在某个条件下)。 例如: 1.定时器函数 var a 1setItercal( function(){aconsole.log(a)},1000)//延时器var a 1setTimeout( functi…

C++中回调函数的一个简单例子?

回调函数应用实例: 1、定义一个Person类 (Person.h)文件: 注意:在这个类中指定了回调函数,回调函数的执行者,和回调函数指针 重要的是 回调函数和回调函数指针是怎么关联的? 2、…

一个简单的jQuery回调函数例子

欢迎扫码加入Java高知群交流 jQuery回调函数简单使用 比如说,我们想要点击某个按钮后触发事件, 先把一些指定内容给隐藏掉, 然后跳出相关信息的对话框。 如果使用普通的方法, 不用回调函数的话, 会有怎么样的效…

【C语言】回调函数

目录 前言 一、回调函数是什么? 二、使用步骤 1.举例 2.库函数中的例子 3.模拟实现qsort()函数 前言 随着我们对C语言的学习以及对指针更加深入的了解,我们避免不了接触到回调函数,以下是关于回调函数的知识分享。 一、回调函数是什么…

C语言回调函数一个简单的例子

回调函数通俗的解释: 普通函数:你所写的函数调用系统函数,你只管调用,不管实现。 回调函数:系统调用你所写的函数,你只管实现,不管调用。 以下是使用C语言实现回调函数的一个例子&a…

JS回调函数——简单易懂有实例

初学js的时候&#xff0c;被回调函数搞得很晕&#xff0c;现在回过头来总结一下什么是回调函数。什么是JS&#xff1f;&#xff08;点击查看&#xff09; 下面先看看标准的解释&#xff1a; <script language"javascript"> 02 function SortNumber( obj, …

C语言回调函数详解(全网最全)

文章目录 一、函数指针1.概念2,如何用函数指针调用函数3.**函数指针作为某个函数的参数**4.函数指针作为函数返回类型5.函数指针数组6.函数指针总结 二、回调函数1.什么是回调函数2 为什么要用回调函数&#xff1f;3 怎么使用回调函数&#xff1f;4.下面是一个四则运算的简单回…

回调函数(简单易懂)

因为今天又遇到新的回调函数的形式 callback && callback()&#xff1b;所以搜了一下回调函数&#xff0c;发现真的好多人写得好复杂啊&#xff0c;看得我昏昏欲睡还是看不懂&#xff0c;还有看到有的人说是 主函数执行完再去执行回调函数&#xff0c;我顿时无语&…

回调函数的使用(完整例程)

前提是了解函数指针的基本用法&#xff08;定义函数指针以及调用&#xff09;&#xff0c;可以看下面这个帖子&#xff0c;一步到位 函数指针的一个定义和两个调用 实战&#xff08;完整代码例子&#xff09; #include<bits/stdc.h> using namespace std; int add(int …

C语言 - 详解回调函数

回调函数和函数指针 回调函数就是一个通过函数指针调用的函数。如果你把函数的指针&#xff08;地址&#xff09;作为参数传递给另一个 函数&#xff0c;当这个指针被用来调用其所指向的函数时&#xff0c;我们就说这是回调函数。回调函数不是由该函数 的实现方直接调用&#…

【Linux rar,unrar命令安装详细实践】

本教程是参考【1】进行实践的&#xff0c;在实践过程中发现一些问题&#xff0c;因此做了一些补充 实践过程 本安装命令在Linux命令下执行 本人是在pycharm下&#xff0c;连接的远程Linux服务器下创建的一个conda环境中运行Linux命令 参考资料教程代码 1. wget https://www.…