一文弄清混合云架构模式

news2024/10/2 12:26:47

当我们在说云架构的时候,通常指的并不是云平台的自身架构,而是基于云平台的软件系统基础架构。云平台的自身架构满足了很多通用层面的需求,例如对象存储,弹性主机,虚拟网络等等,只有云服务厂商的工程师才会涉及。对于一般企业中的工程师而言, 鉴于云服务的各种优势,基于云平台构建软件系统才是工作的内容之一,尤其是面向混合云的基础架构才是云架构的关键要素。

无论是公有云和私有云的融合,还是多个公有云的混合环境,其基础架构模式分为两种:分布式部署模式和冗余部署模式。在决定合适的架构时需要考虑的5个相关方面: 变更的敏捷性、规模的伸缩性、网络拓扑选择、安全性和可靠性。

分布式部署模式

当我们需要利用云服务的某些特性、属性或功能时,这些模式最为有用。


敏捷性伸缩性网络拓扑安全性可靠性
分层混合模式前端受益于CI/CD的流水线前端受益于弹性缩放由网关控制的MeshVPN隧道后端或许成为瓶颈
分区多云模式CI/CD完全融合,并保证标准化能够按需缩放由网关控制的MeshVPN隧道需要额外保证通信的可靠性
云分析模式采用一致性过程能够按需缩放根据数据的收发/切换来变更拓扑,并采用API网关进行控制TLS订阅/发布机制实现可靠性集成
边云混合模式确保边和云之间的标准化边缘计算之外的按需缩放双向网关控制VPN隧道和TLS跨边界的可靠性验证

分层混合模式

经典的分层通常由前端和后端应用程序组成。前端处理终端用户/客户,消费者或他们的组合。一般地,前端是无状态的,在这种情况下,性能和灵活性对于处理不可预测的工作负载是非常重要的。另外,通常还要处理大量的变化,因此可以从敏捷思维中受益。后端根据监管要求安全地存储数据,并且应该不那么频繁地进行更改。

6e3ff93de8e17939eda0ccc20018b04b.jpeg

这种架构模式的思想是迁移每个应用程序,首先选择一个不太复杂的应用程序,然后逐个进行。一般地,有6种云迁移策略,通常称为“6R”:主机更新、平台更新、重新购买、重构、保留、停服。因此,需要针对每种情况做出架构决策。迁移之后,它们通过 API 网关访问后端,这个网关集中关注交叉问题,如安全性、速率限制、 API 策略等。

如果正处于迁移过程的中期,而公司不能承诺同时完成所有工作时,这是一个很好的模式,除非情况很简单,否则总是如此。

分区多云模式

如果关注可移植性,那么这种模式提供了将工作负载从一个云平台转移到另一个云平台的能力。该模式的优势是锁定风险并进行缓解,能够从每个供应商挑选最佳功能并完成监管。

55fa08b86549486e9f79f1544213a87f.jpeg

实现跨多个云环境的工作负载可移植性和一致性的工具增加了开发、测试和运维的工作。可移植性性是有代价的,为了使可移植性最大化,一般会考虑容器和K8S。

云分析模式

一般地,企业架构通常由事务系统和分析系统组成。事务系统用于执行每天的财务、销售、库存、定价等操作,而分析系统通常由于变化的性质和速度不同而与其他系统解耦。

3b24df1b9f8744825009e6ca8aa72d17.jpeg

此模式的核心思想是在云中拥有分析工作负载,并在需要时反馈数据。云存储可以使用数据湖来实现,并通过BOS引入流量。

边云混合模式

有些时候,我们的业务不可能能100% 的依赖于连接,比如车辆间的连接性,工厂的可用性服务水平超过了现场链接的能力,商店需要处理关键事务并且链路的宕机是不可能的。

面对这些挑战,边云混合模式通过在网络边缘运行时间敏感和关键业务的本地工作负载,同时使用云处理所有其他类型的工作负载。在边云混合模式的设置中,互联网连接是一个非关键组件,只用于管理的目的和同步或上传数据,通常是异步的,但不涉及时间敏感或关键业务的事务。

5f422bdeba89a74abe55cd746941e499.jpeg

另外,CI/CD的实践在边缘环境和云之间保持一致也是明智的选择。

冗余部署模式

当需要为整个架构增加容量或弹性时,这些模式非常有用。


敏捷性伸缩性网络拓扑安全性可靠性
混合环境模式保证公私有云间的处理流程相同按需创建/删除环境镜像拓扑公私有云间没有通信生产环境在私有云中
业务持续性模式面对故障,CI/CD仍然有效按需创建/销毁灾备环境数据备份的切换以及镜像拓扑 VPN隧道和TLS最小化在不同环境中运行的系统之间的依赖性
面向业务爆发的混合云模式保证公私有云间的处理流程相同按需缩放网格化VPN隧道和TLS跨边界的可靠性验证

混合环境模式

在这种模式中,公共云环境用于开发、测试和 UAT,然后生产环境使用私有云。使用这种架构的原因一般包括:监管限制、第三方许可证的使用,而这些许可证阻止了云中的生产工作负载。如果想要首先替换较低的环境,或者在需要时轻松地创建和关闭环境,那么这种模式可以很好地工作。

50833bc693bb13b82f6c6b437140c449.jpeg

所有环境在功能上都是等价的,即架构、 API 以及操作系统和库的版本都是等价的,并且系统在不同环境中的行为是相同的。但是,性能测试需要在本地实现。

业务连续性混合模式

在这种模式下,灾备环境在云中实现,提供了能够为创建灾难恢复环境并将其关闭的成本效益。另外,在触发灾备的情况下,使用IaaS可以更快地创建灾备环境,从而减少实际的恢复时间。

784fc49ac442fbabfa727ecf6cd50c6e.jpeg

另一种替代方法是将生产环境放在一个程序中,然后故障转移到另一个程序中,但是,这种方法不太常见,因为通常可以在一个程序中实现可用性需求。

面向业务爆发的混合云模式

如果应用程序的工作负载突然增加,不可预测,并且不希望在大部分时间里为某些密集的工作负载期间提供过多的服务,这种模式可能是一种选择,对于可以向上和向下扩展的前端无状态应用特别适合。

3c6683eb67c7be14cedc07e314c35a68.jpeg

面向业务爆发的混合云模式使用一个私有计算环境进行基线负载,并在需要额外容量时暂时爆发到云中。这种模式保留了基础的内部投资,而且不需要维持全年的额外容量。

一句话小结

这些混合云架构模式的决策是复杂的,通常会涉及到几个不同情况的关注程度,每种情况都需要全面的权衡分析,甚至可以使用多种模式来实现企业的解决方案。

那么——

如何进行混合云的架构决策?

如何保持架构的可持续性呢?

《持续架构实践》一书或许可以提供一些真正的帮助。

017842bff1bb46be80e554ca8b1d5056.jpeg

【关联阅读】

  • 软件架构的10个质量属性

  • 端边云协同:从云到边缘

  • 浅析面向云架构的SLA

  • 面向数据架构的云演变

  • IoT云服务连接性的方式

  • 在传感器与云之间

  • 10行Python代码的词云

  • 理解一下混合云

  • 架构软件工程的未来(精要版)

  • 软件架构的10个常见模式

  • 回顾Bob大叔的简洁架构

  • 解读六边形架构

  • 老曹眼中的面向数据架构

  • 从应用架构看大数据

  • 架构大数据应用

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

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

相关文章

Win10系统内置杀毒软件Windows Defender卸载方法

Windows10系统自带的Windows Defender杀毒软件,偶尔会使你的电脑CPU满负荷运载。 其实我们完全可以删除这个Windows10自带的杀毒软件,我们忍耐总是有限度的,所以,你可以选择删除它; 怎么删除呢?下面有个方…

Pthon--自动化实用技巧篇--文件目录处理

为什么要讲这一篇,主要是因为这个在自动化测试框架或者脚本的编写的时候会用到,还是比较方便的。看上述两个函数。getcwd()、chdir()。使用 os.getcwd() 函数获得当前工作目录。使用 os.chdir()函数改变当前工作目录。所以在用chdir()函数的时候别忘记指…

数据类型和变量

目录 ​编辑 一、字面常量 1、字面常量的定义 2、字面常量的分类 二、数据类型 三、变量 1、变量的概念 2、语法格式 3、整型变量 (1)整型变量 (2)长整型变量 (3)短整型变量 (4&a…

带你深入了解c语言指针后续

前言 🎈个人主页:🎈 :✨✨✨初阶牛✨✨✨ 🐻推荐专栏: 🍔🍟🌯 c语言进阶 🔑个人信条: 🌵知行合一 🍉本篇简介:>:介绍c语言中有关指针更深层的知识. 金句分享: ✨在该…

shell学习3

目录 一、查找并删除重复文件 二、列举文件类型统计信息 三、只列出目录 一、查找并删除重复文件 重复文件是同一个文件的多个副本。有时候我们需要删除重复的文件,只保留其中一份。通过查看文件内容来识别重复文件是件挺有意思的活儿。可以结合多种shell工具来完…

阶段六:服务框架基础(第二章Day-MQ(服务异步通讯))

阶段六:服务框架基础(第二章Day-MQ(服务异步通讯))Day-RabbitMQ1.初识MQ1.1.同步和异步通讯1.1.1.同步通讯1.1.2.异步通讯1.2.技术对比:2.快速入门2.1.安装RabbitMQ 【重要】2.1.1、安装RabbitMQ&#xff0…

换掉 Maven,我就用Gradle,急速编译

相信使用Java的同学都用过Maven,这是一个非常经典好用的项目构建工具。但是如果你经常使用Maven,可能会发现Maven有一些地方用的让人不太舒服: Maven的配置文件是XML格式的,假如你的项目依赖的包比较多,那么XML文件就…

[Datawhale][CS224W]图机器学习(六)

目录一、简介二、概述三、算法四、PageRank的缺点五、Python实现迭代法参考文献一、简介 PageRank,又称网页排名、谷歌左侧排名、PR,是Google公司所使用的对其搜索引擎搜索结果中的网页进行排名的一种算法。 佩奇排名本质上是一种以网页之间的超链接个…

蒙特卡洛随机模拟

蒙特卡洛随机模拟 简介 蒙特卡洛模拟是在计算机上模拟项目实施了成千上万次,每次输入都随机选择输入值。由于每个输入很多时候本身就是一个估计区间,因此计算机模型会随机选取每个输入的该区间内的任意值,通过大量成千上万甚至百万次的模拟…

笔记本触摸板没反应怎么办?处理方法看这些

触摸板在笔记本电脑中是非常重要的一部分,很多用户都会选择使用触摸板代替鼠标。然而,有时你可能会发现,你的笔记本电脑触摸板没反应,无法正常使用。这对于日常使用来说是非常困扰的,但不用担心,我们将在这…

JavaScript BOM【快速掌握知识点】

目录 Window对象的常用属性 语法: Window对象的常用方法 语法: open()和close()方法 History对象 常用属性和方法 示例 Location对象 常用属性 常用方法 Document对象的常用方法 定时函数 超时调用:setTimeout() 间歇调用&…

插件化框架shadow——腾讯

theme: cyanosis Shadow简介 Shadow是最近腾讯开源的一款插件化框架。原理是使用宿主代理的方式实现组件的生命周期。目前的插件化框架,大部分都是使用hook系统的方式来做的。使用代理的基本上没有成体系的框架,只是一些小demo,Shadow框架的…

【华为OD机试模拟题】用 C++ 实现 - 查找单入口空闲区域(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 去重求和(2023.Q1) 文章目录 最近更新的博客使用说明查找单入口空闲区域题目输入输出示例一输入输出说明示例二输入输出说明示例三输入输出说明示例

在linux中web服务器的搭建与配置

以下涉及到的linux命令大全查阅 https://www.runoob.com/linux/linux-command-manual.htmlvim命令查阅 https://www.runoob.com/linux/linux-vim.htmlscp命令https://www.runoob.com/linux/linux-comm-scp.html首先要有一个请求的服务地址用ssh 进入到linux系统中ssh 请求的服务…

JavaWeb Servlet Cookie和Session

6、Servlet 6.1、Servlet简介 Servlet就是sun公司开发动态web的一门技术Sun在这些API中提供一个接口叫做:Servlet,如果你想开发一个Servlet程序,只需要完成两个小步骤: 编写一个类,实现Servlet接口把开发好的Java类部…

Redis 4种集群方案介绍+优缺点对比

前言在服务开发中,单机都会存在单点故障的问题,即服务部署在一台服务器上,一旦服务器宕机服务就不可用,所以为了让服务高可用,分布式服务就出现了,将同一服务部署到多台机器上,即使其中几台服务…

【LeetCode】剑指 Offer 17. 打印从1到最大的n位数 p114 -- Java Version

题目链接:https://leetcode.cn/problems/da-yin-cong-1dao-zui-da-de-nwei-shu-lcof/ 1. 题目介绍(17. 打印从1到最大的n位数) 输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直…

<JVM上篇:内存与垃圾回收篇>12 - 垃圾回收相关概念

笔记来源:尚硅谷 JVM 全套教程,百万播放,全网巅峰(宋红康详解 java 虚拟机) 文章目录12.1. System.gc()的理解12.2. 内存溢出与内存泄露内存溢出(OOM)内存泄漏(Memory Leak&#xff…

【Linux驱动开发100问】Linux驱动开发工程师在面试中常被问到的问题汇总

🥇今日学习目标:什么是Kconfig?如何使用Kconfig? 🤵‍♂️ 创作者:JamesBin ⏰预计时间:10分钟 🎉个人主页:嵌入式悦翔园个人主页 🍁专栏介绍:Lin…

针对面试官的盘问-如何回答职场中的一些问题

(点击即可收听)初入职场,面对面试官的提问,如何回答01你为什么从上家公司离职?个人成长不足,不符合自己的预期(关系到个人竞争力,希望找到一份更有挑战,个人提升更大的工作),切忌与面试官倒苦水,说前公司老板的不是业务发展缓慢,上升空间有限(有些不符合…