火山引擎云调度GTM“同城容灾”与“异地多活”实践

news2025/1/24 8:37:20

随着企业不断推进数字化进程,高并发业务和海量数据的挑战也随之而来。在现实生活中,除了地震、台风、挖光纤这种小概率事件,还有很多人为造成的高概率数据丢失事件,比如人为操作失误、硬件故障、网络攻击等等,故障容灾能力的重要性也因此逐渐凸显出来。根据地理位置的不同,灾备方案往往分为同城和异地,今天重点介绍的就是GTM在互联网服务“同城容灾”和“异地多活”场景下的实践应用。

本文带你了解火山引擎边缘云TrafficRoute DNS套件——云调度GTM,它是火山引擎 TrafficRoute 解析调度套件中的全局流量管理服务,基于 DNS 进行流量管理。如果你的业务需要就近接入、负载均衡、流量调度和故障容灾能力,那么火山引擎云调度GTM可以帮助到你。

云调度GTM

对照以下表格,我们先来理解GTM的基本能力,再看这些能力在实现过程中如何应对不同的调度和故障场景。

图片

互联网服务的“同城容灾”

当用户服务部署在同一个区域的多个机房时,如公有云的XX云在华东某个城市包含两个可用区机房1/机房2,一旦其中某个机房发生故障,将基于预案进行自动或手动故障转移,确保服务不中断或快速恢复。

同城容灾有以下3种参考模式:

  • 冷备:同区域的2个机房采用“主-备”模式,即主机房平时承载流量,备机房不承载流量,当主机房故障时,流量迁移到备机房。该模式部署简单,但有两个缺点:第一是平常状态下的资源浪费;第二是主机房故障时,由于平时没有流量,备机房的后端配置、容量、各系统状态等是否“Ready”是不可知的。

  • 热备:同区域的两个机房采用“主-备”模式,主机房平时承载主要流量,备机房承载少量流量,这部分流量用来验证备机房的功能是否可用。这个模式解决了故障发生时备机房没有准备好的问题,但还是无法解决常态下一半资源的浪费和备用机房有可能出现容量不足的问题。

  • 双活:同区域的两个机房在常态下同时进行工作,当一个机房故障时,流量切换到另一个机房。由于常态下的同时工作,所以不存在是否“Ready”的问题,只需要关注故障时另一个机房能否承载流量即可。这个模式下,同一个区域多个机房也是可行的,冗余会更高,对非故障机房承载故障机房流量时,要保留“剩余容量”的要求就更低了,当然多个机房也可能带来数据/配置一致性等问题。

适用场景

同城容灾适用于距离较近的场景,包括同城多个机房、几个相邻的自建机房通过流量转发组成“同城/区域”等情况,支持通过主备(冷、热备)、双活(多活)等模式实现同城情况下的容灾,典型例子就是公有云同城内部的若干机房之间的容灾。

注:上述“冷备”,“热备”等名词定义并不严谨,文内只为解释不同模式之间的区别。

参考架构

图片

架构图中,将公有云的Region替换成“同城”,AZ换成普通机房也同样适用。这种情况下,机房入口(例如一个Region)使用一个负载均衡的CNAME标记集群是可以的,同时集群内部,如多个AZ之间也支持流量相互转发,负载均衡层面对用户会屏蔽AZ的细节。

优势介绍

  • 低成本:建设成本低、架构入侵小、适配性强;配置和管理简单;确保多IDC环境下服务不中断或者快速恢复;

  • 按需选择:可根据需要实现“冷备”、“热备” 和 “双活(多活)”;

  • 灵活配置:支持健康检查和自动容灾,也支持手动模式和多个预案的配置(结合在多个PoolSet间切换);

  • 方便管理:便于进行流量灰度和AB测试、流量机房间迁移等。

方案实践

图片

互联网服务的“异地多活”

在同城容灾的基础上,流量的调度容灾可以扩展到更大的范围。为了在性能、冗余(数据备份)和容灾上有更多的余地,全国/全球性的互联网服务通常采用多中心场景,包含多云、混合云,这要求我们不仅要做到同城一个机房/单个AZ故障时的容灾,也要做到多个地域部署服务时,地域级别故障下的异地灾备,确保服务的连续工作。当然,这需要解决多个地区、机房之间的流量均衡问题,确保每个机房的水位安全。

这就涉及到了异地灾备方案,由于异地的IDC转发延时较同城大,Region间的流量转发通常存在性能、成本等问题,可以通过做异地多活架构来替代流量转发,多个公有云的Region大体属于此类情况。

由于异地多活是一个相对复杂的话题,例如如何保持数据的一致性等,所以我们更关注从公网流量角度出发,进行容灾“多活”的举措。

适用场景

机房位于全国/全球多个位置,需要实现按地区的流量调度/均衡、跨地区的备份和流量灾备。例如,公有云多个区域之间的“多活”,或者距离较远的几个自建核心机房之间的灾备和服务多活。

参考架构

图片

上图是参考架构示意图,更关注外部流量的容灾方案。机房内部服务有多种选择,VM、容器、微服务等,而DB、MQ、缓存等的异地容灾也应该单独考虑。

优势介绍

  • 部署简单:建设成本低、架构入侵小、适配性强;配置和管理简单;同时具备区域内多个机房(AZ)和跨区域的容灾能力;AZ故障时由LB进行同Region其他AZ转发,可以实现大家常说的“两地三中心”+“同城容灾/异地多活”;

  • 多种模式:支持健康检查、自动容灾和手动模式,手动模式便于配置多个供选择的容灾预案;

  • 多区可用:适用于多机房、多Region流量均衡、灰度和AB测试;

  • 统一管理:可实现多地区、多机房、运营商、IP流量的统一管理和调度。

方案实践

图片

写在最后

完善的灾备方案在保证业务的持续性上不可或缺,火山引擎云调度 GTM基于解析进行流量调度,可以实现流量的就近接入(地理位置/性能)、负载均衡 。GTM借助分布式、多协议健康检查能力来实现故障容灾(Failover),诸如上文说到的“同城容灾”、“异地多活”等场景。此外 GTM 还提供了多云环境下的流量编排、资源粘合能力,可视化的健康检查数据分析、操作日志等功能帮助排查定位问题,便于日常运维。

当前,TrafficRoute DNS套件下的各个产品,包括云调度 GTM、私网解析PrivateZone、移动解析HTTPDNS和公共解析PublicDNS,服务了抖音,头条,飞书和火山引擎ALB、CDN、动态加速、存储等各类APP和云产品,具备重要产品稳定服务的能力,在技术、成本、性能和产品成熟度方面拥有深厚积累。

TrafficRoute DNS套件已正式上线火山引擎官网,欢迎访问【火山引擎官网】,了解更多TrafficRoute DNS套件相关信息。

关于火山引擎边缘云:

火山引擎边缘云,以云原生技术为基础底座,融合异构算力和边缘网络,构建在大规模边缘基础设施之上的云计算服务,形成以边缘位置的计算、网络、存储、安全、智能为核心能力的新一代分布式云计算解决方案。

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

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

相关文章

RISC-V中国峰会 | 256核服务器高调亮相,谁与争锋?

8月23日,第三届RISC-V中国峰会(RISC-V Summit China 2023)在北京香格里拉饭店正式开幕,来自世界各地的行业精英汇聚一堂,为RISC-V生态系统建言献策,凝心聚力! 中国工程院院士倪光南、RISC-V国际…

C++多线程编程——thread线程创建与使用(2W字保姆级介绍)

目录 前言 线程创建 标准库thread(同步线程的创建过程) 启动线程:实例thread 线程执行单元(可调用对象) 线程等待 线程传参 线程id 成员方法获取线程id 命名空间获取线程id 让出线程资源 sleep_for() sle…

聊一聊微前端框架的选型和实现 | 业务平台

一、项目背景 目前,我们开发维护的项目主要有 6 个,但是分别对应 PC 和 H5 两个端: 如上图所示,我们 6个项目最开始是一个一个进行开发维护的,但是到后期,这几个项目之间有的部分会有业务逻辑不同&#xff…

docker高级(mysql主从复制)

数据库密码需要设置成自己的!!! 1、创建容器master13307 #docker pulldocker run -p 13307:3306 --name mysql-master \ --privilegedtrue \ -v /mysql/mysql-master/log:/var/log/mysql \ -v /mysql/mysql-master/data:/var/lib/mysql \ -…

centos 下扩容根目录

大体情况: 在VM虚拟机上安装了移动云的BCLinux镜像,磁盘设定为8G,但是用过一段时间之后根目录下磁盘已满,无法创建文件夹等操作,因此在VM上进行了磁盘扩容,扩容之后需要在系统上自行挂载,使用m…

【VsCode】SSH远程连接Linux服务器开发,搭配cpolar内网穿透实现公网访问(1)

文章目录 前言1、安装OpenSSH2、vscode配置ssh3. 局域网测试连接远程服务器4. 公网远程连接4.1 ubuntu安装cpolar内网穿透4.2 创建隧道映射4.3 测试公网远程连接 5. 配置固定TCP端口地址5.1 保留一个固定TCP端口地址5.2 配置固定TCP端口地址5.3 测试固定公网地址远程 前言 远程…

【linux】基本指令(二)【man、echo、cat、cp】

目录 一、man指令二、echo指令三、cat指令二、cp指令一些常见快捷键 一、man指令 Linux的命令有很多参数,我们不可能全记住,可以通过查看联机手册获取帮助。访问Linux手册页的命令是 man 语法: man [选项] 命令 常用选项 1.-k 根据关键字搜索联机帮助 2…

面试题-React(六):React组件和生命周期

一、React组件 React组件简介: React组件是构建用户界面的基本单元。它们将界面拆分成独立、可重用的部分,使得代码更加模块化、可维护性更高。React组件可以是函数组件或类组件,它们接收输入的数据(称为props)并返回…

ORB-SLAM2算法11之地图点MapPoint

文章目录 0 引言1 MapPoint类1.1 构造函数1.2 成员函数1.2.1 AddObservation1.2.2 EraseObservation1.2.3 SetBadFlag1.2.4 Replace1.2.5 ComputeDistinctiveDescriptors1.2.6 UpdateNormalAndDepth1.2.7 PredictScale 2 MapPoint类用途 0 引言 ORB-SLAM2算法7详细了解了Syste…

Webstorm 入门级玩转uni-app 项目-微信小程序+移动端项目方案

1. Webstorm uni-app语法插件 : Uniapp Support Uniapp Support - IntelliJ IDEs Plugin | Marketplace 第一个是不收费,第二个收费 我选择了第二个Uniapp Support ,有试用30天,安装重启webstorm之后,可以提高生产率…

排序链表-归并排序

给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。 示例 1: 输入:head [4,2,1,3] 输出:[1,2,3,4] 示例 2: 输入:head [-1,5,3,4,0] 输出:[-1,0,3,4,5] 示例 3: 输…

vue 展开和收起

效果图 代码块 <div><span v-for"(item,index) in showHandleList" :key"item.index"><span>{{item.emailFrom}}</span></span><span v-if"this.list.length > 4" click"showAll !showAll">{…

Ceph入门到精通-大流量10GB/s LVS+OSPF 高性能架构

LVS 和 LVSkeepalived 这两种架构在平时听得多了&#xff0c;最近才接触到另外一个架构LVSOSPF。这个架构实际上是LVSKeepalived 的升级版本&#xff0c;我们所知道LVSKeepalived 架构是这样子的&#xff1a; 随着业务的扩展&#xff0c;我们可以对web服务器做水平扩展&#xf…

聚观早报 | 云鲸扫拖机器人J4体验;芯科科技第三代无线开发平台

【聚观365】8月24日消息 云鲸扫拖机器人J4体验 芯科科技推出第三代无线开发平台 英伟达与VMWare宣布扩大合作 万物新生&#xff08;爱回收&#xff09;2023年二季度财报 充电桩需求增长带动汽车后服务市场 云鲸扫拖机器人J4体验 家庭卫生清洁是每个人都无法回避的事情&am…

实训笔记8.24

实训笔记8.24 8.24笔记一、Sqoop数据迁移工具1.1 Sqoop的基本概念1.2 Sqoop的基本操作1.2.1 命令语法1.2.2 list-databases1.2.3 list-tables1.2.3 eval1.2.4 import1.2.5 export1.2.6 导入 二、Flume日志采集工具2.1 数据采集的问题2.2 数据采集一般使用的技术2.3 扩展&#x…

Tokenview再度升级:全新Web3开发者APIs数据服务体验!

Tokenview发布全新版本的区块链APIs和数据服务平台&#xff0c;为开发者打造更强大、更便捷的开发体验&#xff01; 此次升级&#xff0c;我们整合了开发者使用习惯以及Tokenview产品优势。我们深知对于开发者来说&#xff0c;时间是非常宝贵的&#xff0c;因此我们努力提供一…

联合注入步骤

使用场景&#xff1a; 有回显&#xff0c;可以看到某些字段的回显信息 像下面的有具体的回显信息 一、判断注入位点 在原始的id&#xff08;参数&#xff09;的输入后面添加额外的条件 如果and 11 有结果&#xff0c;and10没有结果输出&#xff0c; 就说明我们添加的额外条件…

sqlmap安装以及运用

目录 一、sqlmap简介 linux系统安装 windows系统安装 二.sqlmap确定目标 (1) sqlmap直连数据库 (2) sqlmap的URL探测 (3) Sqlmap文件读取目标 (4) Sqlmap Google批量扫注入 一、sqlmap简介 sqlmap是一个开源的渗透测试工具&#xff0c;它可以自动化检测sql注入漏洞利用…

opencv 文档识别+UI界面识别系统

目录 一、实现和完整UI视频效果展示 主界面&#xff1a; 识别结果界面&#xff1a; 查看处理图片过程&#xff1a; 查看历史记录界面&#xff1a; 二、原理介绍&#xff1a; 将图像变换大小->灰度化->高斯滤波->边缘检测 轮廓提取 筛选第三步中的轮廓&#xf…

Unity OnDrawGizmos的简单应用 绘制圆形

编辑器和配置表各有各的好。 卡牌游戏即使再复杂&#xff0c;哪怕是梦幻西游&#xff0c;大话西游那种&#xff0c;甚至wow那种&#xff0c;用配表都完全没问题。但是崩坏3&#xff0c;或者鬼泣&#xff0c;格斗游戏&#xff0c;可视化编辑器是唯一的选择。 开发初期刚开始配技…