云原生架构

1. 何为云原生?
很多IT业内小伙伴会经常听到这个名词,那么什么是云原生呢?云原生是在云计算环境中构建、部署和管理现代应用程序的软件方法。 当今时代,众多企业希望构建高度可扩展、灵活且有弹性的应用程序,以便能够快速更新以满足客户需求。 因此,推荐使用本质上支持云基础设施上的应用程序开发的现代工具和技术。 这些云原生技术支持对应用程序进行快速、频繁的更改,而不影响服务交付,从而为采用者提供创新的竞争优势。

2. 云原生有何优势?

(1)提高效率
云原生开发带来了 DevOps 和持续交付 (CI/CD) 等敏捷实践。 开发人员使用自动化工具、云服务和现代设计文化快速构建可扩展的应用程序。

(2)降低成本
通过采用云原生方法,公司无需投资昂贵的物理基础设施的采购和维护。 这可以长期节省运营支出。 构建云原生解决方案所节省的成本也可能使您的客户受益。

(3)提高可用性
云原生技术使公司能够构建有弹性且高度可用的应用程序。 功能更新不会导致停机,公司可以在旺季扩大应用程序资源,以提供积极的客户体验。

3. 什么是云原生应用程序?
云原生应用程序是由多个小型、相互依赖的服务(称为微服务)组成的软件程序。 传统上,开发人员使用包含所有必需功能的单个块结构构建整体应用程序。 通过使用云原生方法,软件开发人员将功能分解为更小的微服务。 这使得云原生应用程序更加敏捷,因为这些微服务独立工作并需要最少的计算资源来运行。

4. 云原生应用与传统企业应用的比较
传统的企业应用程序是使用不太灵活的软件开发方法构建的。 开发人员通常会在发布大量软件功能进行测试之前对其进行开发。 因此,传统企业应用程序的部署时间较长且不可扩展。

另一方面,云原生应用程序使用协作方法,并且在不同平台上具有高度可扩展性。 开发人员使用软件工具在云原生应用程序中高度自动化构建、测试和部署过程。 您可以立即设置、部署或复制微服务,这是传统应用程序无法实现的操作。

5. CNCF

提到云原生就必须介绍一个组织 - 云原生计算基金会 (CNCF) ,它是一个开源基金会,可帮助组织启动云原生之旅。 CNCF 成立于 2015 年,支持开源社区开发关键的云原生组件,包括 Kubernetes等,很多大型云厂商是该基金会成员,如亚马逊。

6. 什么是云原生应用架构?
云原生架构结合了开发团队用来构建和运行可扩展的云原生应用程序的软件组件。 CNCF 将不可变基础设施、微服务、声明式 API、容器和服务网格列为云原生架构的技术模块。

(1)不可变的基础设施 Immutable Infra
不可变的基础设施意味着用于托管云原生应用程序的服务器在部署后保持不变。 如果应用程序需要更多计算资源,则旧服务器将被丢弃,并将应用程序迁移到新的高性能服务器。 通过避免手动升级,不可变的基础设施使云原生部署成为一个可预测的过程。

(2)微服务 Microservices
微服务是小型、独立的软件组件,它们共同作为完整的云原生软件运行。 每个微服务都专注于一个小的具体问题。 微服务是松散耦合的,这意味着它们是相互通信的独立软件组件。 开发人员通过处理各个微服务来对应用程序进行更改。 这样,即使一个微服务发生故障,应用程序也可以继续运行。

(3)应用程序编程接口 API
应用程序编程接口(API)是两个或多个软件程序用来交换信息的方法。 云原生系统使用 API 将松散耦合的微服务整合在一起。 API 告诉您微服务需要什么数据以及它可以为您提供什么结果,而不是指定实现结果的步骤。

(4)服务网格 Service Mech
服务网格是云基础设施中的一个软件层,用于管理多个微服务之间的通信。 开发人员使用服务网格引入附加功能,而无需在应用程序中编写新代码。

(5)容器

容器是云原生应用程序中最小的计算单元。 它们是打包云原生系统中的微服务代码和其他所需文件的软件组件。 通过容器化微服务,云原生应用程序独立于底层操作系统和硬件运行。 这意味着软件开发人员可以在本地、云基础设施或混合云上部署云原生应用程序。 开发人员使用容器来打包微服务及其各自的依赖项,例如主应用程序运行所需的资源文件、库和脚本。

7. 什么是云原生应用程序开发?
云原生应用程序开发描述了开发人员如何以及在何处构建和部署云原生应用程序。 文化转变对于云原生开发非常重要。 开发人员采用特定的软件实践来缩短软件交付时间并提供准确的功能来满足不断变化的用户期望。 下面我们给出了一些常见的云原生开发实践。

(1)持续集成 - CI (Continuous Integration)
持续集成 (CI) 是一种软件实践,开发人员可以频繁且无错误地将更改集成到共享代码库中。 频繁的小更改可以提高开发效率,因为您可以更快地识别和解决问题。 CI 工具会自动评估每次更改的代码质量,以便开发团队可以更有信心地添加新功能。

(2)持续交付 - CD (Continuous Delivery)
持续交付(CD)是一种支持云原生开发的软件实践。 通过 CD,开发团队可确保微服务始终准备好部署到云中。 他们使用软件自动化工具来降低进行更改时的风险,例如引入新功能和修复应用程序中的错误。 CI 和 CD 协同工作以实现高效的软件交付。

(3)DevOps
DevOps 是一种改善开发和运营团队协作的软件文化。 这是一种与云原生模型相一致的设计理念。 DevOps 实践使组织能够加快软件开发生命周期。 开发人员和运维工程师使用DevOps工具来自动化云原生开发。

(3)Serverless
Serverless计算是一种云原生模型,其中云提供商完全管理底层服务器基础设施。 开发人员使用无服务器计算,因为云基础设施会自动扩展和配置以满足应用程序要求。 开发人员只需为应用程序使用的资源付费。 当应用程序停止运行时,无服务器架构会自动删除计算资源。

云原生架构_第1张图片

你可能感兴趣的:(持续集成/交付,深入Java,阿里云架构实战,云原生,架构,微服务)