MySQL高可用(MHA高可用)

什么是 MHA

MHA(MasterHigh Availability)是一套优秀的MySQL高可用环境下故障切换和主从复制的软件。

MHA 的出现就是解决MySQL 单点的问题。

MySQL故障切换过程中,MHA能做到0-30秒内自动完成故障切换操作。

MHA能在故障切换的过程中最大程度上保证数据的一致性,以达到真正意义上的高可用。

MHA 的组成

●MHA Node(数据节点)

MHA Node 运行在每台 MySQL 服务器上。

●MHA Manager(管理节点)

MHA Manager 可以单独部署在一台独立的机器上,管理多个 master-slave 集群;也可以部署在一

台 slave 节点上。

MHA Manager 会定时探测集群中的 master 节点。当 master 出现故障时,它可以自动将最新数据

的 slave 提升为新的 master, 然后将所有其他的 slave 重新指向新的 master。整个故障转移过程

对应用程序完全透明。

MHA 的特点

●自动故障切换过程中,MHA试图从宕机的主服务器上保存二进制日志,最大程度的保证数据不丢

●使用半同步复制,可以大大降低数据丢失的风险,如果只有一个slave已经收到了最新的二进制日

志,MHA可以将最新的二进制日志应用于其他所有的slave服务器上,因此可以保证所有节点的数

据一致性

●目前MHA支持一主多从架构,最少三台服务,即一主两从

一主俩从初始化

7-5主

7-3/4从

7-7服务端

在7-7上安装软件包

 

回主服务器对接7-7

显示失败

修改配置文件 

至此四台主机时间同步

给四台主机设置配置文件

 

给三台MySQL服务端配置文件

id号分别为:1、2、3 

登录数据库(三都做)

 创建用户并授权(三都做)

刷新(三都做)

查看二进制文件

俩从服务器对接主服务器

俩从服务器

所有MySQL

主服务器创建表

从服务器做检查

回7-7

到opt目录创建文件

 移动在线源

 安装依赖包

移动包

将包打包给主服务器

回主服务器

再将包移动到其他服务器 

从库

三个在线源仓库都改

重新安装

主服务器解压软件包并安装(四都做)

 

#manager 组件安装后在/usr/local/bin 下面会生成几个工具,主要包括以下几个:
masterha_check_ssh 检查 MHA 的 SSH 配置状况
masterha_check_repl 检查 MySQL 复制状况
masterha_manger 启动 manager的脚本
masterha_check_status 检测当前 MHA 运行状态
masterha_master_monitor 检测 master 是否宕机
masterha_master_switch 控制故障转移(自动或者手动)
masterha_conf_host 添加或删除配置的 server 信息
masterha_stop  关闭manager
 

免交互  

回7-7

复制

替换脚本

复制脚本到上一层目录中

创建目录

创建一个配置文件

回主服务器配置IP地址

 返回7-7 

三个服务器都做

删文件重新复制

创建日志

宕机主服务器

故障切换到从服务器

自动退出进程

配置也将自动删除 

从服务器指向新的主服务器7-3

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

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

相关文章

内容营销专家刘鑫炜:如何撰写一篇吸睛又能转化的医疗推广软文?

在我每天要处理的稿件中,有1/3以上是医疗软文,但稿件质量情况不容乐观,大部分医疗软文甚至用极其糟糕来形容都为过,互联网都到下半场了,很多医疗机构营销人员的营销思维还是停留在二十几年前,投放的软文还是…

SpringMVC系列八: 手动实现SpringMVC底层机制-第三阶段

手动实现SpringMVC底层机制 实现任务阶段六🍍完成控制器方法获取参数-RequestParam1.🥦将 方法的 HttpServletRequest 和 HttpServletResponse 参数封装到数组, 进行反射调用2.🥦在方法形参处, 指定 RequestParam, 将对应的实参封装到参数数组…

Perl正则表达式捕获组:深入探索与实战应用

🕵️‍♂️ Perl正则表达式捕获组:深入探索与实战应用 在Perl的世界里,正则表达式是其强大的文本处理能力的基石。捕获组作为正则表达式中的一个核心概念,允许我们从匹配的文本中提取子字符串。本文将深入探讨如何在Perl中使用正…

【AI应用探讨】—k-means应用场景

目录 数据挖掘 图像分析 自然语言处理 生物信息学 物流配送优化 公共安全与城市规划 社交网络分析 数据挖掘 市场分析:在市场营销中,企业可以利用K-means算法对消费者进行聚类分析,根据消费者的购买行为、消费习惯等信息将客户分成不同…

Redis缓存问题二、缓存雪崩

缓存雪崩 缓存雪崩:是指在同一时段大量的缓存key同时失效或者Redis服务宕机,导致大量请求到达数据库,带来巨大压力。 缓存雪崩的解决方案: 给不同的Key的TTL添加随机值利用Redis集群提高服务的可用性给缓存业务添加降级限流策略…

sql-语句

文章目录 SQL语句的学习sql是什么sql的内置命令sql的种类sql mode库,表属性介绍:字符集,存储引擎列的数据类型:数字,字符串,时间列的约束DDL: 数据定义语言库表 Online DDL(ALGORITHM) *DML :数据操纵语言资…

Zookeeper怎么用

ZooKeeper 的使用方式通常涉及以下几个核心方面: 1. 安装和配置 ZooKeeper 服务 首先,需要在网络中的多台服务器上安装和配置 ZooKeeper 服务。通常情况下,ZooKeeper 至少需要三台服务器来保证服务的高可用性和容错性。安装和配置可以参考 Zo…

SpringBoot实现文章点赞功能

提示:今日是2024年的6月30日,未来的你看到这篇文章,希望你依旧快乐 文章目录 前言 首先在这里前缀部分我就不做要求了,比如说登录信息什么的 数据库表格 这里实现点赞功能,主要是围绕论坛项目完成的 user_info代表用户信息表 for…

python库 - tqdm

文章目录 主要特点安装基本用法1. 在 for 循环中使用2. 在 enumerate 中使用3. 自定义描述信息4. 在多线程中使用 高级用法1. 手动更新进度条2. 嵌套进度条 tqdm 是一个用于 Python 的快速、可扩展的进度条库。它可以在长循环中提供即时的进度反馈,帮助开发者了解代…

SprongBoot3整合Knife4j

大家好,我是晓凡。 写在前面 在上一篇文章,我们详细介绍了SpringBoot3 怎么整合SpringDoc实现在线接口文档。但是,有不少小伙伴 都觉得接口界面太丑了。有没有什么更美观一点的UI界面呢? 当然是有的了,毕竟这是一…

抖音直播自动点赞脚本:让点赞变得简单

抖音直播自动点赞脚本:让点赞变得简单 简介 点赞是社交媒体上表达喜爱的一种方式,尤其在抖音这样的平台上,点赞不仅能够增加主播的人气,还能鼓励他们创作更多优质内容。然而,手动点赞往往既耗时又费力。为了解决这个…

云服务出现故障这样处理

无法连接云服务器 服务器远程无法连接时,可通过7ECloud控制台进行连接。 常见故障现象 1、ping不通 2、ping丢包 3、部分端口telnet不通 4、全部端口telnet不通 5、广告、弹窗植入 6、域名无法访问IP访问正常 常见故障原因 1、云服务器过期、关机或者EIP被…

CentOS 7 上搭建 JavaEE 环境

CentOS 7 上搭建 JavaEE 环境 安装 Java 环境 1)检查系统中是否已安装 Java java -version如果未安装,将返回提示信息。 2)安装 Java 8 sudo yum install java-1.8.0-openjdk3)配置 Java 环境变量,编辑 /etc/prof…

深度学习基准模型Transformer

深度学习基准模型Transformer 深度学习基准模型Transformer,最初由Vaswani等人在2017年的论文《Attention is All You Need》中提出,是自然语言处理(NLP)领域的一个里程碑式模型。它在许多序列到序列(seq2seq&#xf…

恭喜了!全体前端彻底狂欢吧!这个好消息来得太及时!

在这个快速变化的科技时代,作为独立开发者,你是否常常被繁琐的开发任务压得喘不过气?前端开发要操心后端的各种服务搭建和接口开发,这些琐碎而耗时的工作常常让人头大。但现在,你可以松一口气了,因为MemFir…

【ARM-Linux篇】项目:智能家居

一、项目概述 •项目功能 通过语音控制客厅灯、卧室灯、风扇、人脸识别开门等,可以进行火灾险情监测,可以并且实现Sockect发送指令远程控制各类家电等 •项目描述 全志H616通过串口连接各模块硬件,检测语音的识别结果,分析语音识别的结果来对家电设备进行控制。摄像头拍…

java 创建带参数的对象

在Java中,可以使用构造方法来创建带参数的对象。构造方法是一个特殊的方法,用来初始化对象的属性。 以下是创建带参数的对象的步骤: 在类中定义一个带参数的构造方法,方法名与类名相同。在构造方法中定义参数,并通过…

Elasticsearch的Mapping

Elasticsearch的Mapping Mapping是什么 Mapping定义了ES的索引结构、字段类型、分词器等,是索引的一部分。类似于关系型数据库中“表结构”的概念,在 Mapping 里也包含了一些属性,比如字段名称、类型、字段使用的分词器、是否评分、是否创建…

视频上面怎样编辑文字?4种视频编辑文字方法分享

视频已成为我们日常生活中不可或缺的一部分。无论是社交分享、商业宣传还是个人记录,视频都以其直观、生动的特点吸引着观众的眼球。然而,一个优质的视频,除了画面和音效,文字编辑也是提升观看体验的关键。那么,如何在…

Webpack: 并行构建

概述 受限于 Node.js 的单线程架构,原生 Webpack 对所有资源文件做的所有解析、转译、合并操作本质上都是在同一个线程内串行执行,CPU 利用率极低,因此,理所当然地,社区出现了一些以多进程方式运行 Webpack&#xff0…