写点什么

我们为什么选择云原生应用?

  • 2022-02-24
  • 本文字数:2317 字

    阅读完需:约 8 分钟

我们为什么选择云原生应用?

我想,世上没有人会不知道“云”这个词。我指的并不是天空中的那些白色物体。问题在于,在技术领域,很少有人能真正理解这个词的真正含义。在本文中,我不会对这个领域进行更深入的探讨,而是将重点放在对云原生应用和传统企业应用的对比上。


所以,在我们开始之前,我们要先了解一下这两种观念,以便我们能够更好地了解我们到底在比较什么。

传统企业应用


这种类型的应用是老式的单体应用。它们通常采用瀑布方法(或者是一些缓慢的 Scrum 尝试),并且与首次部署时所用到的软硬件密切联系在一起。它们对操作系统有着很大的依赖性,并且要求物理资源不易扩充,而且即使工程师在某些部分使用了微服务,它们也仍然是以单体应用的方式进行部署。这些应用的进一步开发往往会花费更多的时间和更多的成本。也会花费更多的时间在可扩展性上,并且无法根据“按需”来更改。在 10~20 年前,云服务几乎不存在的时候,它们的普及率是相当高的,但我们也要记得,那时候 IT 产业还很小,资金只集中在相当少的关键参与者。这个事实的重要性将在本文稍后加以论述。

云原生应用


这个术语描述了一种应用,它依赖于云计算的很多优势,并且建立在微服务架构之上。重要的是要记住,云原生开发的应用是一个描述它们如何创建、维护和优化的想法。这并不意味着这些数据会被存储到云端中,而是可以在本地存储,但是依然可以从云原生方式中获益。这对于监管非常严格的市场尤为重要。


这些类型的应用程序也受益于 CI(持续集成)和 CD(持续部署)解决方案。


更让我们感到困惑的是,还有一种基于云的应用的概念。它们通常是描述迁移到云端的传统企业应用。它仍然代表了其前辈的许多不足之处。在本文中,我们不会对此进行太多的讨论,但是我只想提及一下,以便你对此有一个全面的认识。


传统企业应用的缺点


在本文中,我(可能你已经看出来了)正在推广云原生应用的想法,因此我将重点放在老式方法的缺点上。这并不代表没有优点,只是我觉得没有必要去描述这些优点。


传统企业应用最大的缺点就是单体环境,这就要求采用瀑布方法来解决任何新的特性或者已存在的特性的改变。它们的测试环境往往与生产环境相差甚远,这就增加了在部署之后发生重大问题的可能性。

因为传统企业应用对硬件和操作系统的依赖性很强,因此很难对其进行移植或扩充。这将导致大量的开发成本和宝贵的时间。此外,在扩充方面,我们要注意的是,传统的企业应用都是建立在预期流量基础上的。所以,如果超出了这些假定的极限,那么就无法处理所有的峰值(我们也要记住,这些应用是在互联网规模相当小的时候被创造出来的)。


它们的备份和恢复过程通常是很有限的,而且很难实施。


正如你所看到的,这种方法有相当严重的后果,对业务造成了很严重的影响。就像我之前提到过的,在 20 年前,由于那时候的行业和现在完全不同,所以这些因素都没有太大的影响。现在,推出市场的时机非常关键,还有可维护性和团队士气。如果我们采用这样的方法,那么我们就很难在市场上保持竞争力,并且无法满足客户所要求的质量和标准。

为什么云原生应用(很可能)是最佳选择


受益于云原生方法的一个最有趣的特点是,即使是旧的单体应用都可以通过 Docker 的方式迁移到云端。这样,Docker(或者其他工具)在让我们利用云计算的网络解决方案的时候,给我们一个传统的环境。这也让我们有机会把传统的架构逐渐转变成像微服务这样的云原生架构,再逐步淘汰掉传统的解决方案。


我决定从它的好处开始说起,因为这会让那些停仍留在 IT 远古时代的人们看到希望。


但是,回归到它的好处——它可以把一个应用从一个操作系统或者一个硬件中完全抽象出来,这就为我们提供了无限的可能。这让工程师可以集中精力在自己的实际工作上,而不用去考虑那些由不得他们决定的软硬件的依赖性。新的抽象层让所有事情都变得简单了,而且,你猜怎么着,更快。


当涉及硬件能力时,云原生方法赋予了工程师完全的控制权,并且可以根据需要进行扩大和缩小规模。它既简单又有效,使你的客户无论在什么样的流量都能从你的软件中获益。而另一方面,你的企业可以更好地控制价格昂贵的资源的成本,确保你只支付你实际需要的费用。这也让我们能够更好地控制部署流程,降低风险和重要问题的数量。


在这种类型的组织中,团队合作本身也是非常容易的。团队可以很容易地被分成较小的组织,分别负责特定的服务或领域(如安全)。利用合适的工作,使他们可以彼此协作,即使他们不在同一个部分工作。除了这些,他们还可以通过持续集成中获益,因为持续集成能够保持对代码质量的关注,确保任何被部署的东西都能保持一定的质量和安全水平。


最后,但并非不重要的是,人们还必须看一下可用的备份和恢复选项。这使得整个环境对他们的客户来说更加安全和有效,从而能够最大限度降低停机时间。而且我们都知道,每次事故都要花掉一大笔钱(对于大型科技公司来说,你可以很容易地看出股价和事故之间的相关性)。

结论


嗯,我猜你也许会说,这太显而易见了。老实说,我实在不愿意说某种解决方案是最好的方法。但是,在这个例子中,我实在难以为传统企业应用方法提供任何理由。每次我要做出技术决策的时候,我都会优先考虑业务方面的问题。在云原生应用中,业务方面的好处非常多,很难争论。速度,开放的协作环境,安全,可维护性,可扩展性和安全性。所有这些因素似乎都在高呼“选我!”。


最后一个想法是——我极力建议你在做出技术决策的时候,把业务因素考虑进去。


作者介绍:


Sunscrapers Team,使有远见的领导者能够通过产生实际业务成果的解决方案来驾驭数字化转型的浪潮。由于采用了敏捷和精益的创业方法,Sunscrapers 以最高的速度和效率提供高质量的软件。


原文链接:


https://sunscrapers.com/blog/cloud-native-apps-vs-traditional-apps/

2022-02-24 14:242644

评论

发布
暂无评论
发现更多内容

一文读懂 TypeScript 泛型及应用

阿宝哥

Java typescript 大前端

架构师0期04周命题作业

我在终点等你

原创 | TDD工具集:JUnit、AssertJ和Mockito (二十四)编写测试-内建扩展

编程道与术

Java 编程 TDD 单元测试 JUnit

Linux 性能优化实战 笔记-IO篇

程序员老王

ARTS 第 4 周

乌拉里

谈一谈年终奖中的那些坑

张小方

程序员 面试 offer 薪资 年终奖

聊一聊 HashMap

江城子

Java hashmap

分布式系统架构学习总结(第四周)

~就这样~

系统结构:作业

梅子黄时雨

极客大学架构师训练营

使用 Flutter 快速实现请假与写周报应用

LeanCloud

flutter 后端 数据 教程

让你秒懂Spring中Mybatis的花样配置

小谈

Java spring 面试 Spring Cloud mybatis

架构师训练营第四周感悟

张锐

极客大学

环信荣登36氪WISE2020企服金榜-智能客服榜首

DT极客

如何构建你自己的 JVM (2) HelloWorld

孤星可

Java JVM 深入理解JVM

年薪百万架构师推荐的888页Java王者级核心宝典,offer直接来

无予且行

javascript 部分数据类型的用法

Isuodut

【思考】-产品等级与市场定位匹配

superman

定位 产品定位

这20道微服务面试题要是不会,offer就与你无缘

犬来八荒

Java 架构 面试 微服务

极客大学架构师训练营 系统架构 第8课 听课总结

John(易筋)

极客时间 系统架构 极客大学 极客大学架构师训练营 系统架构演化

攻克SpringBoot底层源码后,才发现开发原来这么香

无予且行

Java spring 面试 Spring Boot 开发

从0-1学习项目方案设计

赵孔磊

一个典型的大型互联网应用系统使用了哪些技术方案和手段,主要解决什么问题?请列举描述。

~就这样~

Java 面试必考的 6 个技能,都在这了

架构大数据双料架构师

慧点OA转战政企市场,钉钉们羡慕么?

人称T客

week 04 作业

Safufu

week 04 总结

Safufu

系统架构:学习小结

梅子黄时雨

极客大学架构师训练营

计算机操作系统基础(九)---存储管理之段页式存储管理

书旅

php laravel 线程 操作系统 进程

架构师0期04周总结

我在终点等你

Week4总结

王志祥

极客大学架构师训练营

从 0 到 1 搭建技术中台之推送平台实践:高吞吐、低延迟、多业务隔离的设计与实现

伴鱼技术团队

kafka 缓存 分布式架构 消息推送 push

我们为什么选择云原生应用?_云原生_Sunscrapers Team_InfoQ精选文章