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

article/2025/11/10 11:36:07

文章目录

  • MySQL数据库集群(双主双从)
      • 实验环境
      • 双主双从
          • 双主
          • 双从
          • 进行测试

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

实验环境

保证每台centos7服务器配置静态的IP,初始化服务器,关闭防火前和selinux,保证四台服务器之间可以互相通信,并且做好hosts域名解析。

vi  /etc/hosts

在这里插入图片描述

双主双从

双主

主服务器单节点设置,如果主服务器故障则会影响全局的写入事件,所以要设置为双主。在前面的实验中已经将master1设置为master2的主服务器,这里只需要设置master2为master1的主服务器。

设置master2为master1的主服务器

  • 登录master2的mysql数据库授权并且刷新
grant replication slave,replication client on *.* to 'rep'@'192.168.83.%' identified by 'Mysql@123';
flush privileges;# 刷新

在这里插入图片描述

  • 登录master1的数据库并且操作:
change master to master_host='master2',master_user='rep',master_password='Mysql@123',master_auto_position=1;
start slave;# 开启奴隶模式
show slave status\G;

这时master1也是别人的主服务器,同样也是别人的从服务器,master1和master2互为主从服务器。

  • 测试

master1上面插入数据,在master2上观察数据是否同步
在master2上面插入数据,在master1上观察数据是否同步

如果有问题可以在/var/log/mysqld.log查看,双方互相同步。

双从

有另外两台的mysql数据库作为服务器

同步现有的数据库

使用mysqldump备份master1的数据

mysqldump -p'Mysql@123' --all-databases --single-transaction --master-data=2 --flush-logs > mmss-mysql-all.sql

备份完成后将sql文件传送给slave1和slave2

scp -r master1:/mmss-mysql-all.sql slave1:/tmp/
scp -r master1:/mmss-mysql-all.sql slave2:/tmp/

分别登录slave1和slave2并且手动同步数据
slave1和slave2

mysql -uroot -p'Mysql@123' < /tmp/mmss-mysql-all.sql

启动从服务器的ID和GTID

开启slave1和slave2的二进制日志功能和服务器ID和GTID
slave1的数据库:

vi /etc/my.cnf

另起几行写到

server-id=3
gtid_mode=ON
enforce_gtid_consistency=1
master-info-repository=TABLE
relay-log-info-repository=TABLE

保存退出并且重启slave1的数据库

systemctl restart mysqld

slave2的数据库:

vi /etc/my.cnf
server-id=4
gtid_mode=ON
enforce_gtid_consistency=1
master-info-repository=TABLE
relay-log-info-repository=TABLE

保存退出并且重启slave2的数据库

systemctl restart mysqld

设置主服务器

登录slave1的数据库

change master to master_host='master1',master_user='rep',master_password='Mysql@123',master_auto_position=1 for channel 'master1';
change master to master_host='master2',master_user='rep',master_password='Mysql@123',master_auto_position=1 for channel 'master2';
start slave;#开启奴隶模式

查看运行状态

show slave status\G;

登录slave2的数据库并进行操作

change master to master_host='master1',master_user='rep',master_password='Mysql@123',master_auto_position=1 for channel 'master1';
change master to master_host='master2',master_user='rep',master_password='Mysql@123',master_auto_position=1 for channel 'master2';
start slave;#开启奴隶模式

查看运行状态

show slave status\G;

双方的数据已经同步了。
如果集群有问题,可以去/var/lib/mysql/中的所有文件进行删除,重启数据库后就是一个全新的数据库。

进行测试

可以分别在master1和master2中插入数据进,可以在slave1和slave2中进行查看,验证实验是否成功


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

相关文章

数据库与集群

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

数据库-mysql集群方案总结

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

数据库集群

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

MySQL数据库的集群方案

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

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

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

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

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

回调函数

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

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

回调函数应用实例&#xff1a; 1、定义一个Person类 &#xff08;Person.h&#xff09;文件&#xff1a; 注意&#xff1a;在这个类中指定了回调函数&#xff0c;回调函数的执行者&#xff0c;和回调函数指针 重要的是 回调函数和回调函数指针是怎么关联的&#xff1f; 2、…

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

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

【C语言】回调函数

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

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

回调函数通俗的解释&#xff1a; 普通函数&#xff1a;你所写的函数调用系统函数&#xff0c;你只管调用&#xff0c;不管实现。 回调函数&#xff1a;系统调用你所写的函数&#xff0c;你只管实现&#xff0c;不管调用。 以下是使用&#xff23;语言实现回调函数的一个例子&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.…

Mac Terminal菜鸟篇之使用unrar解压rar文件

在Mac上的归档工具不能够解压rar文件&#xff0c;这时可以使用终端中的unrar来解决问题。 步骤如下&#xff1a; 1.使用Homebrew安装unrar&#xff08;有关Homebrew的安装和使用见Homebrew&#xff09; $ brew install unrar > Downloading http://www.rarlab.com/rar/unr…

Mac用homebrew安装unrar

原来安装方法 brew install unrar 现在安装方法 brew install rar 安装后软件路径为: /opt/homebrew/Caskroom/rar/6.12/rar 安装后的rar软件包含rar和unrar两个命令 如果用以前旧命令会提示找不到该软件名字&#xff0c;用现在方法可以直接安装rar和unrar命令&#xff…

unrar file.rar 解压rar 问题,找不到unrar 命令。安装rar unrar流程及bug处理

在使用unrar e file.rar 解压时报错&#xff0c;需要安装rar 1.安装流程 1.1 用户 如果是root用户则不需要进行切换用户&#xff0c;否则 切换到root用户下【权限问题】 例如&#xff1a;$su root 1.2 下载 cd 指定路径&#xff0c;eg: cd /export/software wget http://w…