MySQL双主双从数据库集群搭建

1 引言

      在之前的文章中提到过单主单从的搭建方法,具体请参考《MySQL主从数据库搭建》这篇文章,本文主要讲述双主双从,双主多从集群的搭建方式。 这里要问一个问题,为什么MySQL要搭建数据库集群呢?我想应该有以下几点原因:

  • 提高性能:通过搭建数据库集群,可以将负载分散到多个服务器上,从而提高了数据库的整体性能。这主要是因为集群的每个节点都可以独立地处理请求,减轻了单个服务器的负担。
  • 高可用性:在数据库集群中,如果一个节点发生故障,其他的节点可以接管并继续处理请求。这种故障转移能力可以大大提高系统的可用性和稳定性。
  • 可扩展性:数据库集群可以方便地增加或减少节点,以适应业务需求的变化。这种可扩展性使得系统能够灵活地应对不同的情况。
  • 数据备份与恢复:在数据库集群中,可以设置多个节点来存储相同的数据,从而实现数据备份和冗余。这样,即使某个节点发生故障,也可以从其他节点获取数据。
  • 负载均衡:通过集群,可以在多个节点之间分配用户请求,从而实现负载均衡。这有助于确保每个节点都保持合理的负载,避免过载的情况。
  • 安全性:集群环境中的多个节点可以提供更好的数据安全保护;例如,如果某个节点受到攻击或发生故障,其他节点可以继续处理数据,降低安全风险。
  • 容错性:在集群中,如果某个节点发生故障,其他节点可以接管并继续提供服务。这种容错能力可以提高系统的稳定性和可用性。

      总的来说,MySQL搭建数据库集群可以带来很多好处,如提高性能、高可用性、可扩展性、数据备份与恢复、负载均衡等。这些优点有助于确保系统的稳定运行和满足不断增长的业务需求

2 双主双从

      搭建双主双从需要使用6台服务器,两个主节点,每个主节点各自有两个从节点,这里采用的是docker的部署方式,如果缺乏docker运行环境,请参考《CentOS7安装Docker运行环境》这篇文章进行配置,配置完成后使用下列语句拉取MySQL镜像并创建运行MySQL镜像实例,这里采用了MySQL5.7.26版本进行创建。创建语句如下:

docker run -p 3306:3306 --name mysql --restart=always --privileged=true -v /mnt/mysql/log:/var/log/mysql -v /mnt/mysql/data:/var/lib/mysql -v /mnt/mysql/conf:/etc/mysql -v /etc/localtime:/etc/localtime:ro -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.26

      使用docker ps 查看一下执行结果:
在这里插入图片描述
      这6台服务器都按照上述方法配置后就可以开始搭建集群了。

2.1 集群划分

      6台服务器如下表所示,读者可根据自己的实际情况选择其他的固定IP。

序号角色IP地址
1master1172.16.17.231
2master2172.16.17.232
3slave1172.16.17.233
4slave2172.16.17.234
5slave3172.16.17.235
6slave4172.16.17.236

2.2 集群架构图

      其中一个主机master1负责处理所有写请求,当master1宕机后,master2负责接替master1对外恢复数据库服务。slave1、slave2、slave3、slave4负责所有读请求,分摊读请求的压力。
在这里插入图片描述

2.3 配置

      根据前文提到的目录(/mnt/mysql/conf)下创建my.cnf文件

2.3.1 主节点

      在my.cnf文件中添加如下配置:

[mysqld]
# 设置字符集
character-set-server=utf8mb4
# 设置排序规则
collation-server=utf8mb4_general_ci
# 允许最大连接数
max_connections=200
# 设置临时表最大大小
tmp_table_size=128M
# 设置最大内存使用量
max_heap_table_size=1024M
# 服务器唯一ID
server-id=1
# 启用二进制日志
log-bin=mysql-bin
# 设置需要复制的数据库,这里以test为例
binlog-do-db=db1
# 设置不需要复制的数据库(可以设置多个)
binlog-ignore-db=mysql
binlog-ignore-db=information-schema
# 设置logbin格式
binlog_format=statement
# 在作为从数据库的时候,有写入操作也要更新二进制日志文件
log-slave-updates
[client]
default-character-set=utf8mb4

      以db1作为需要同步的数据库,binlog-do-db这个属性也可以根据读者需要改成自己需要同步的数据库名称。注意:log-slave-updates这个属性一定要添加不然修改master1的数据,master读取到之后,它的从机无法同步到数据。

2.3.2 从节点

      修改配置文件

vi /mnt/mysql/conf/my.cnf

      具体配置如下:

[mysqld]
# 设置字符集
character-set-server=utf8mb4
# 设置排序规则
collation-server=utf8mb4_general_ci
# 允许最大连接数
max_connections=200
# 设置临时表最大大小
tmp_table_size=128M
# 设置最大内存使用量
max_heap_table_size=1024M
server-id=3
relay-log=mysql-relay
[client]
default-character-set=utf8mb4

      按照上面对主从节点的配置,根据架构图中标识的server-id分别修改6台服务器的MySQL配置文件。

2.3.3 重启服务

      使用下述命令分别重启6台服务器的MySQL容器

docker restart mysql

2.3.4 创建同步slave账号并授权

步骤1: 分别进入master1和master2服务器docker容器,登录MySQL

docker exec -it mysql /bin/bash
mysql -uroot -p123456

步骤2: 创建slave账号并授权

create user 'slave'@'%' IDENTIFIED by '123456';
GRANT REPLICATION SLAVE ON *.* TO 'slave'@'%' IDENTIFIED BY '123456';

2.3.5 主从配置

步骤1: 登录主节点,查询master1的状态

msql -uroot -p123456
show master status

执行结果如下:
在这里插入图片描述
      记录File和Position两列的值。用以配置从节点
步骤2:登录从节点,配置需要复制的主机
      登录从节点

msql -uroot -p123456
CHANGE MASTER TO MASTER_HOST='主节点IP地址',
MASTER_USER='slave',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='刚刚记录的File值',MASTER_LOG_POS=刚刚记录的Position值;

      示例:

CHANGE MASTER TO MASTER_HOST='172.16.17.231',
MASTER_USER='slave',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=154;

步骤3:启动从节点复制功能

start slave;

步骤4:查看从节点状态

show slave status\G

执行结果:

*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: 172.16.17.231Master_User: slaveMaster_Port: 3306Connect_Retry: 60Master_Log_File: mysql-bin.000001Read_Master_Log_Pos: 154Relay_Log_File: mysql-relay.000003Relay_Log_Pos: 367Relay_Master_Log_File: mysql-bin.000001Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: Replicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0Last_Error: Skip_Counter: 0Exec_Master_Log_Pos: 154Relay_Log_Space: 570Until_Condition: NoneUntil_Log_File: Until_Log_Pos: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 1Master_UUID: be75605d-4620-11ee-8b15-0242ac110002Master_Info_File: /var/lib/mysql/master.infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Slave has read all relay log; waiting for more updatesMaster_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: 
1 row in set (0.00 sec)

      查看Slave_IO_Running、Slave_SQL_Running属性都是Yes,则说明主从配置成功
slave3 重复步骤1-5进行配置,slave2、salve4与slave1、slave3类似,只不过登录主机换成master2,步骤2中的ip需要换成master2的IP(172.16.17.232)

2.3.6 双主配置

      与主从配置类似,master2需要复制master1、master1需要复制master2
master2复制master1:

CHANGE MASTER TO MASTER_HOST='172.16.17.231',
MASTER_USER='slave',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=154;

master1复制master2:

CHANGE MASTER TO MASTER_HOST='172.16.17.232',
MASTER_USER='slave',
MASTER_PASSWORD='123456',
MASTER_LOG_FILE='mysql-bin.000001',MASTER_LOG_POS=154;

主节点启动从服务器复制功能:

start slave;

查看主节点从服务状态:

show slave status\G;

      具体细节语句会和实际略有出入,读者根据自己的环境调整一下IP和端口之类的参数。

额外的一些命令(如无需要可以跳过):

# 停止从服务复制功能
stop slave;
# 重新配置主从
stop slave;
reset master;

3 测试

      master1创建一张表并插入一条数据,master2、slave1、slave2、slave3、slave4也做出了相应的变更即代表成功,master2反之亦然。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/209234.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

彻底解决ModuleNotFoundError: No module named ‘exceptions‘【Bug完美解决】

文章目录 项目场景:问题描述原因分析:解决方案:此Bug解决方案总结心得项目场景: 根据本文可找到bug原因并彻底解决**ModuleNotFoundError: No module named ‘exceptions‘**Bug 报错: E:\Anconda\python.exe c:\Users\24190\PycharmProjects\pythonProject4py尝试 gong…

Android textView 显示: STRING_TOO_LARGE

在Android中,字符串资源的长度限制是32KB,getString()方法返回的字符串资源的大小超过这个限制,就会抛出STRING_TOO_LARGE 这个错误。 我本地的临界值是:32.3 KB (33,090 字节) 小于等于33090时,能正常显示&#xff…

数据结构和算法-树与二叉树的存储结构以及树和二叉树和森林的遍历

文章目录 二叉树的存储结构二叉树的顺序存储二叉树的链式存储小结 二叉树的先中后序遍历例题小结 二叉树的层次遍历小结 由遍历序列构造二叉树一个遍历序列即使给定了前中后序,也不能确定该二叉树的形态可以确定的序列组合前序中序后序中序层序中序 小结若前序&…

构建第一个ArkTS应用(纯HarmonyOS应用)

1. 安装开发工具 在华为开发者官方上下载HarmonyOS应用专用的开发工具,链接地址:HUAWEI DevEco Studio和SDK下载和升级 | HarmonyOS开发者 要想使用开发工具让项目跑起来,需要10G的磁盘空间。开发工具需要的磁盘空间为2.36G;SDK需…

springBoot整合task

springBoot整合task 文章目录 springBoot整合task开开关设置任务,并设置执行周期定时任务的相关配置 开开关 设置任务,并设置执行周期 Component public class MyBean {Scheduled(cron "0/1 * * * * ?")public void print(){System.out.prin…

Shutdown Signal: channel error; protocol method: #method<channel.close>

完整异常信息&#xff1a; Shutdown Signal: channel error; protocol method: #method<channel.close>(reply-code404, reply-textNOT_FOUND - no exchange fanoutExchange in vhost /, class-id60, method-id40) 意思是找不到名字是 fanoutExchange 的虚拟机 就是虚拟机…

JVM基础篇:垃圾回收

目录 1.前言 1.1C/C的内存管理 1.2Java的内存管理 2.方法区的回收 3.堆回收 3.1引用计数法和可达性分析法 3.2五种对象引用 强引用 软引用 弱引用 虚引用 终结器引用 3.3垃圾回收算法评价标准 ①吞吐量 ②最大暂停时间 ③堆使用效率 3.4垃圾回收算法 ①标记清…

RabbitMQ 笔记

Message durability 确保消息在server 出现问题或者recovery能恢复&#xff1a; declare it as durable in the producer and consumer code. boolean durable true; channel.queueDeclare("hello", durable, false, false, null);Queue 指定 //使用指定的queue&…

【古月居《ros入门21讲》学习笔记】14_参数的使用与编程方法

目录 说明&#xff1a; 1. 参数模型&#xff08;全局字典&#xff09; 2. 实现过程&#xff08;C&#xff09; 创建功能包 参数命令行的使用 YAML参数文件 rosparam命令 使用示例 编程方法&#xff08;C&#xff09; 配置代码编译规则 编译并运行 编译 运行 3. 实…

基于springboot + vue体育馆使用预约平台

qq&#xff08;2829419543&#xff09;获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;springboot 前端&#xff1a;采用vue技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xf…

Wireshark 协议插件Lua开发 -数据包内嵌协议的解释

概述 因为公司项目涉及的协议打包&#xff0c;协议包内又嵌了一层IP包的奇葩套娃结构&#xff0c;为了方便抓包调试&#xff0c;利用Wireshark的协议插件开发功能&#xff0c;写了一个插件&#xff0c;博文记录以备忘。 环境信息 Wireshark 4.0.3 协议结构体套娃图 插件安装…

C++基础 -35- string类

string类的格式 string a;如下图&#xff0c;使用string类比常规的字符串处理方便很多 而且需要进行的字符串处理&#xff0c;在类中都能完成 #include "iostream"using namespace std;extern "C" {#include "string.h" }int main() {//c的写…

从零开始:PHP实现阿里云直播的简单方法!

1. 配置阿里云直播的推流地址和播放地址 使用阿里云直播功能前&#xff0c;首先需要在阿里云控制台中创建直播应用&#xff0c;然后获取推流地址和播放地址。 推流地址一般格式为&#xff1a; rtmp://{Domain}/{AppName}/{StreamName}?auth_key{AuthKey}-{Timestamp}-{Rand…

C# 使用HtmlAgilityPack解析提取HTML内容

写在前面 HtmlAgilityPack是一个HTML解析类库&#xff0c;日常用法就是爬虫获取到内容后&#xff0c;先用XPath获取目标节点&#xff0c;再用正则进行匹配&#xff1b;使用XPath的目的主要是将目标节点或内容限定在一个较小的范围&#xff0c;如果一上来就用正则那效率肯定不…

Git Bash环境下用perl脚本获取uuid值

在Linux环境下&#xff0c;比如在ubuntu就直接有uuidgen命令直接获取uuid值。在Windows环境下常用的git bash中没有对应的命令&#xff0c;略有不便。这里用脚本写一个uuidgen&#xff0c;模拟Linux环境下的uuidgen命令。 #! /usr/bin/perl use v5.14; use Win32;sub uuidGen {…

Windows驱动中校验数字签名(使用 ci.dll)

1.背景 对于常规应用程序来说&#xff0c;校验数字签名认证在应用层可以使用 WinVerifyTrust, 在驱动层使用常规的 API无法使用&#xff0c;自己分析数据又太麻烦。 在内核中 ci.dll 包装了数据签名验证相关的功能&#xff0c;我们可以使用该 dll 来实现我们的数字签名验证。 详…

Blender学习笔记:小车狂奔动画

文章目录 路旁小树汽车尾气移动 教程地址&#xff1a;八个案例教程带你从0到1入门blender【已完结】 小车建模 路旁小树 1 添加摄像机&#xff0c;在小车下面拉一个平面&#xff0c;覆盖到摄像机的观察视窗。复制一层平面&#xff0c;收窄变成小车两侧的路面&#xff0c;编辑…

vue使用实现录音功能js-audio-recorder

前言 最近项目中需要实现一个录音上传功能&#xff0c;用于语音评论可以上录音。 下载插件&#xff1a; npm i js-audio-recorder完整代码 <template><div style"padding: 20px;"><h3>录音上传</h3><div style"font-size:14px"…

图推理:忠实且可解释的大型语言模型推理11.29

推理&#xff1a;忠实且可解释的大型语言模型推理 摘要1 引言&#xff12; 相关工作3 准备工作4 方法4.1 图推理&#xff1a;规划-检索-推理4.2 优化框架4.3 规划模块4.4 检索推理模块 5 实验5.1 实验设置5.2 RQ1&#xff1a;KGQA 性能比较 摘要 大型语言模型&#xff08;LLM&…

python爬虫AES魔改案例:某音乐素材下载网

声明&#xff1a; 该文章为学习使用&#xff0c;严禁用于商业用途和非法用途&#xff0c;违者后果自负&#xff0c;由此产生的一切后果均与作者无关 一、找出需要加密的参数 js运行 atob(‘aHR0cHM6Ly93d3cuYWlnZWkuY29tL3NvdW5kL2NsYXNzLw’) 拿到网址&#xff0c;F12打开调…