查看原文
其他

HA(高可用) 技术全面介绍

运维派 Linux云计算网络 2021-12-21

阅读本文大概需要 5.5 分钟。

作者:运维派
来源:http://uee.me/aYhrV


HA(High Availability)的定义

可用性

提供在本地系统的单个组件故障情况下,能够继续访问应用的能力,最好的可用性就是,如果一台机器宕机了,使用服务的用户完全感觉不到。

故障恢复

如果出现宕机,在该机器上运行的服务肯定得做故障切换(failover),切换主要分为两个维度:

  • RTO(Recovery Time Objective):主要是指服务恢复的时间

  • RPO(Recovery Point Objective):主要是指切换时向前恢复的数据的时间长度,RPO=1天意味着恢复时使用一天前的数据,那么一天之内的数据就丢失了。

补充概念

  • Active/Passive:主要包括一台活动提供服务的服务器和一台待命不对外提供服务的服务器,一般在讲failover就是属于这个,也是cluster HA基本款。

  • Active/Active:两台(或N台)同时运作,每台机器可以跑一个运行的实例,当一台机器出现宕机时,就会将运行的实例切换到另外一台机器上去,那么另外一台机器就会运行两个实例,AA模式保证了两台机器资源都被利用。

HA(High Availability)的实现

(一)冗余

硬件

  • 电源:采用双路供电

  • 磁盘:可以分为RAID0、RAID1、RAID5等

    • RAID0:又称为stripe或者striping,代表了RAID级别中最高的存储性能,原理就是把连续的数据分散到多个磁盘上进行存取,这样,系统有数据请求就可以被多个磁盘并行的执行,每个磁盘执行属于它自己的那部分数据请求,这样可以充分利用总线的带宽。

    • RAID1:通过磁盘数据镜像实现数据冗余,在成对的独立磁盘上产生互为备份的数据,当原始数据繁忙时,可直接从镜像拷贝中读取数据,这样就提高了读取性能,并保证了数据的可靠性和安全性。当一个磁盘失效时,系统就可以自动切换到镜像磁盘上读写。

    • RAID5:可以理解为RAID0和RAID1的折中方案,可以为系统提供数据安全保障,但保障程度要比mirror低,而磁盘空间利用率要比mirror高。

    • RAID10:主要是一个RAID0和RAID1的结合,利用奇偶校验实现条带集镜像,继承了RAID0的快速和RAID1的安全

  • 网卡:(bonding,双路)在linux服务器上可以利用bonding技术,将多个网卡当做一个网卡使用,不仅提高了带宽而且提高了可用性。

  • 交换机:LACP、VRRP

  • LACP(Link Aggregration Control Protocol,链路汇聚控制协议):是一种实现链路动态汇聚的协议,LACP协议通过LACPDU(LACP Data Unit,链路汇聚控制协议数据单元)与对端交互信息。当启用某一端口的LACP协议后,该端口将发送LACPDU向对端通告自己的系统优先级,系统MAC地址,端口优先级,端口号和操作Key。对端接受到这些信息后,将这些信息与其他端口所保存的信息比较以选择能够汇聚的端口,从而双发可以对端口加入或退出某个动态汇聚组达成一致。

  • 虚拟路由冗余协议(Virtual Router Redundancy Protocol,简称VRRP)是由IETF提出的解决局域网中配置静态网关出现单点失效现象的路由协议,VRRP广泛应用在边缘网络中,它的设计目标是支持特定情况下IP数据流量失败转移不会引起混乱,允许主机使用单路由器,以及及时在实际第一跳路由器使用失败的情形下仍能够维护路由器间的连通性。

软件

  • 协议:HTTP、广播

  • 负载均衡:LVS、haproxy、nginx

  • LVS 采用IP负载均衡技术和基于内容请求分发技术。调度器具有很好的吞吐率,将请求均衡地转移到不同的服务器上执行,且调度器自动屏蔽掉服务器的故障,从而将一组服务器构成一个高性能的、高可用的虚拟服务器。整个服务器集群的结构对客户是透明的,而且无需修改客户端和服务器端的程序。为此,在设计时需要考虑系统的透明性、可伸缩性、高可用性和易管理性。

  • Nginx 是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。

  • HAProxy 提供高可用性、负载均衡以及基于TCP和HTTP应用的代理,支持虚拟主机,它是免费、快速并且可靠的一种解决方案。HAProxy特别适用于那些负载特大的web站点,这些站点通常又需要会话保持或七层处理。

  • 集群:主主、主备;同步,异步

(二)校验

  • checksum(TCP校验和):是一个端到端的校验和,由发送端计算,然后由接收端验证。

  • CRC(Cyclic redundancy check循环冗余校验):主要用来检验数据传输和保存后可能出现的错误,生成的数字在传输的过程或者存储之前计算出来并且附加到数据的后面。

  • 重传

(三)综合

  • 校验+冗余

(四)Failover

又称故障切换,指系统中其中一项设备或服务失效而无法运作时,另一项设备或服务即可自动接手原失效系统所执行的工作。

为了实现自动的故障切换,通常需要在冗余的组件之间启用心跳机制,以相互检测彼此的状态,在检测到故障时自动进行切换。

  • 监控

  • 切换

(五)相关软件

  • keepalived

  • pacemaker

  • heartbeat + DRBD(AP实现方式)

DRBD(Distributed Replicated Block Device)是一个用软件实现的、无共享的、服务器之间镜像块设备内容的存储复制解决方案。号称“网络RAID”。通过网络通信来同步镜像整个设备,当数据写入本地的DRBD设备上的文件系统时,数据会同时被发送到网络中的另外一台主机之上,并以完全相同的形式记录在一个文件系统中。本地节点(主机)与远程节点(主机)的数据可以保证实时的同步,并保证IO的一致性。



后台回复“加群”,带你进入高手如云交流群。如果你喜欢本文,不妨分享给你喜欢的朋友读,或者点下右下角的“在看”,谢谢了!


推荐阅读:

阿里云 K8S 集群网络详解

收藏!!BAT 程序员们常用的开发工具

详细介绍Linux文件系统:各种目录一网打尽

为什么CPU缓存会分为L1、L2、L3?

聊聊几种主流Docker网络的实现原理

到底什么是CDN?一文看懂


喜欢,就给我一个“在看”



10T 技术资源大放送!包括但不限于:云计算、虚拟化、微服务、大数据、网络、Linux、Docker、Kubernetes、Python、Go、C/C++、Shell、PPT 等。在公众号内回复「1024」,即可免费获取!!

: . Video Mini Program Like ,轻点两下取消赞 Wow ,轻点两下取消在看

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存