云原生技术专题 | 深入浅出分析云原生微服务的技术结构和架构设计

简介: 云原生技术专题 | 深入浅出分析云原生微服务的技术结构和架构设计

云原生容器技术背景

容器作为标准化的软件单元,将应用及其依赖打包在一起,实现了应用的环境无关性,使其能够在不同计算环境中快速、可靠地运行。

随着开源的Kubernetes的出现,它展示了出色的开放性、可扩展性,并拥有活跃的开发者社区。

在容器编排领域,Kubernetes已经成为分布式资源调度和自动化运维的事实标准。它屏蔽了不同基础架构(如数据中心、云、边缘计算)的差异,并具备良好的可移植性。通过Kubernetes,企业能够根据自身的业务需求设计其云架构,以更好地支持多云和混合云环境,并摆脱被厂商锁定的担忧。随着容器技术的标准化,Kubernetes进一步推动了容器生态系统的分工和协同发展。在Kubernetes的基础上,生态社区正在构建上层的业务抽象,例如服务网格Istio、机器学习平台Kubeflow、无服务器应用框架Knative等。

容器编排

Kubernetes 已经成为容器编排的事实标准,被广泛用于自动部署,扩展和管理容器化应用。Kubernetes 提供了分布式应用管理的核心能力:

  • 资源调度:根据应用请求的资源量 CPU、Memory,或者 GPU 等设备资源,在集群中选择合适的节点来运行应用;
  • 应用部署与管理:支持应用的自动发布与应用的回滚,以及与应用相关的配置的管理;也可以自动化存储卷的编排,让存储卷与容器应用的生命周期相关联;
  • 自动修复:Kubernetes可以会监测这个集群中所有的宿主机,当宿主机或者OS出现故障,节点健康检查会自动进行应用迁移;K8s也支持应用的自愈,极大简化了运维管理的复杂性;
  • 服务发现与负载均衡:通过Service资源出现各种应用服务,结合DNS和多种负载均衡机制,支持容器化应用之间的相互通信;
  • 弹性伸缩:K8s可以监测业务上所承担的负载,如果这个业务本身的CPU利用率过高,或者响应时间过长,它可以对这个业务进行自动扩容。

Kubernetes控制平面的四大组件

Kubernetes的控制平面包含四个主要的组件:API Server、Controller、Scheduler以及etcd。如下图所示:

Kubernetes在容器编排中的设计要点

  • 声明式API:开发者可以专注于应用程序本身,而不必关心系统的执行细节。Kubernetes提供了不同资源类型(如Deployment、StatefulSet、Job等),用于抽象不同类型的工作负载。采用声明式API的实现方式,与基于"level-triggered"方式相比较,可以实现更强大的分布式系统。
  • 可扩展架构:所有的Kubernetes组件都是基于一致、开放的API实现和交互。第三方开发者可以通过CRD(Custom Resource Definition)/Operator等方式提供领域相关的扩展实现,极大地提升了Kubernetes的能力。
  • 可移植性:Kubernetes(K8s)通过Loadbalance Service(负载均衡服务)、CNI(容器网络接口)和CSl(容器存储接口)等抽象概念,帮助应用屏蔽了底层基础设施的实现差异。这样,业务应用就可以在容器间灵活迁移,实现设计目标的容器灵活性。

云原生微服务典型架构

自2011年以来,微服务架构理念已经演变出了四个典型的架构模式,按照它们出现的顺序进行归纳。

第一代微服务架构

除了实现业务逻辑外,应用程序还需要自己解决上下游寻址、通信和容错等问题。随着微服务规模的扩大,服务寻址逻辑变得越来越复杂。即便是同一编程语言的另一个应用程序,也需要重新实现上述微服务的基础能力。

第二代微服务架构

引入了旁路服务注册中心作为协调者,实现了服务的自动注册和发现。服务之间的通信和容错机制开始模块化,形成了独立的服务框架。然而,随着服务框架内功能的增加,不同语言的基础功能复用变得困难。这意味着微服务的开发者被限制在特定的编程语言上,违背了微服务的敏捷迭代原则。

第三代微服务架构

服务网格架构将原本被模块化到服务框架中的微服务基础能力进一步演进为一个独立进程,即Sidecar。这个变化彻底解决了第二代架构中的多语言支持问题,实现了微服务基础能力与业务逻辑的彻底解耦。这个架构被称为云原生时代的微服务架构,即Cloud Native Microservices。Sidecar进程接管了微服务应用之间的流量,承载了第二代架构中服务框架的功能,包括服务发现、调用容错以及丰富的服务治理功能,例如权重路由、灰度路由、流量重放和服务伪装等。

第四代微服务架构

在这个架构中,微服务进一步简化为微逻辑(Micrologic),边车模式也提出了更高的要求。更多可复用的分布式能力从应用中剥离,并下沉到边车中,包括状态管理、资源绑定、链路追踪、事务管理和安全等。同时,开发侧开始倡导面向localhost编程的理念,提供标准API来屏蔽底层资源、服务和基础设施的差异,从而进一步降低微服务开发的难度。这就是目前业界提出的多运行时微服务架构(Muti-Runtime Microservices)的概念。

未来的云原生架构 — Serverless

随着云原生技术(以Kubernetes为代表)在云计算中扮演着容器界面的角色,Kubernetes变成了新一代云计算操作系统。针对特定领域的后端云服务(BaaS)则提供了在这个操作系统上的服务API。在存储、数据库、中间件、大数据等领域,许多产品和技术都开始提供全托管的云服务。越来越多的用户已经习惯于使用这些云服务,而不再自行搭建存储系统或部署数据库软件。

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
存储 Kubernetes Cloud Native
一文搞懂云原生架构
目前,每个 IT 资源或产品都作为服务提供。而且伴随云计算的滚滚浪潮,云原生(CloudNative)的概念应运而生,云原生很火,火得一塌糊涂,都0202年了,如果还不懂云原生,那真的out了。因此,云原生软件开发成为每个企业的关键要求,无论其规模和性质如何。在加入云计算潮流之前,了解什么是云原生架构以及如何为云原生应用程序需求设计正确的架构非常重要。
一文搞懂云原生架构
|
运维 安全 Cloud Native
谈谈云原生安全
根据自己的理解 简单谈谈云原生安全
4306 0
谈谈云原生安全
|
5天前
|
Cloud Native 微服务
软件体系结构 - 云原生架构
软件体系结构 - 云原生架构
17 7
|
28天前
|
自然语言处理 运维 Cloud Native
云原生技术专题 | 探索云原生化的服务架构体系的技术风向,攻克云原生化微服务架构的痛点和特性
云原生技术专题 | 探索云原生化的服务架构体系的技术风向,攻克云原生化微服务架构的痛点和特性
27 0
|
11月前
|
消息中间件 缓存 前端开发
【架构设计】互联网架构项目架构演进以及三高设计概述
【架构设计】互联网架构项目架构演进以及三高设计概述
【架构设计】互联网架构项目架构演进以及三高设计概述
|
6月前
|
Kubernetes Cloud Native Serverless
云原生:从基本概念到实践,解析演进与现状
云原生:从基本概念到实践,解析演进与现状
99 0
|
9月前
|
运维 Cloud Native IDE
云原生微服务应用的平台工程实践
微服务是一个广泛使用的应用架构,如何使得微服务应用云原生化是近些年一直在演进的课题。本文从云原生应用平台的角度分析云原生化改造中存在的问题,并提出平台工程在开发、测试和 CI/CD 等场景的最佳实践。
|
10月前
|
消息中间件 设计模式 监控
Web开发者的云原生指南(4)微服务架构与设计
在本节中,我们将探讨微服务架构的概念、设计原则以及与之相关的关键主题。我们将详细介绍如何将应用程序拆分成微服务,微服务之间的通信和数据共享,服务注册与发现,以及微服务的容错和弹性设计。此外,我们还将讨论微服务的部署和监控
285 1
|
11月前
|
运维 Cloud Native 微服务
带你读《企业级云原生白皮书项目实战》——4.2.3 微服务概述
带你读《企业级云原生白皮书项目实战》——4.2.3 微服务概述
|
Kubernetes Cloud Native Devops
云原生架构实战-基本概念
基于微服务原理而开发的应用,以容器方式打包。在运行时,容器由运行于云基础设施之上的平台进行调度。应用开发采用持续交付和 DevOps 实践。
216 0
云原生架构实战-基本概念