带你读《弹性计算—无处不在的算力》第三章:计算产品和技术3.6容器服务与弹性容器实例(四)

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 《弹性计算—无处不在的算力》第三章:计算产品和技术3.6容器服务与弹性容器实例(四)

3.6.3 实现技术

与社区开源的Kubernetes 相比,阿里云Kubernetes 服务除了提供便捷的安装、升级及轻松地实现 Kubernetes 集群的扩容和缩容等管理功能,还提供了更为强大的功能,其相关实现组件如图3-78 所示。

……

image.png

3-78  Kubernetes 相关实现组件

1. 自研网络插件

以网络插件为例,围绕Kubernetes 实现的CNI 插件种类丰富、数量繁多。而如何选择一款稳定、高性能,并能支持流量控制、网络策略等高级特性的网络插件, 对于Kubernetes 的网络运行至关重要。以阿里云容器服务的Terway 插件为例,它遵从业界的CNI 设计方式,针对阿里云VPC 网络进行了优化,在Kubernetes 场景下使用,支持网络策略,可以实现Pod 之间的访问隔离。同时,通过在Pod 上声明annotation: k8s.aliyun.com/ingress-bandwidth k8s.aliyun.com/egress-bandwidth 可以限制Pod 的入网和出网带宽。

按照部署和调用方式划分,Terway 包含Daemon Binary 两部分,如图3-79 所示。

image.png


3-79  网络插件Terway

Daemon: Binary 调用,分配和管理网络资源。

Binary: Kubelet 交互及Daemon 交互,配置Pod 的网络连接


Kubelet 监听到Pod 创建在自己的节点上时, 会通过容器运行时创建Sandbox 容器,然后通过cni 调用Terway Binary 来处理网络命名空间,Terway Binary 调用Terway Daemon 来获取网络资源,Terway Daemon 调用Aliyun Open API 分配网络资源并返回给Terway Binary,最后Terway Binary 为容器的网络命名空间配置网络和联通网络。

Serverless Kubernetes 的实现依赖弹性容器实例ECI Virtual Kubelet

2. 弹性容器实例ECI 技术实现

弹性容器实例ECI 提供面向云原生的免运维容器组(Pod)资源交付。用户只需要提供容器镜像,指定ECI 实例规格,即可运行容器实例,无须关心容器运行在哪台物理服务器上。

作为弹性计算的“一等公民”,ECI 充分发挥底层的计算、网络、存储能力,不仅在资源上与ECS 复用整个阿里云弹性计算资源池,还复用了阿里云网络的基础设施,ECI ECS 可以在同一个VPC 内,中间没有虚拟网关的转发开销。ECI 也复用了阿里云存储的基础设施,基于ESSD 的系统盘和数据盘最高可以支持100 万的随机读写IOPS,稳定性和读写带宽都有充分的保障。

资源复用技术

这样做的好处是大幅提升调度的弹性深度。用户直观的感受就是,创建 ECI 的时候除了可以单独指定 CPU、存储容量进行灵活搭配,还可以直接通过 ECS 实例的

规格指定 ECI 的规格,ECI ECS 的资源复用技术,ECI ECS 的资源复用技术如图 3-80 所示。

除了库存的复用,单台物理服务器还支持 ECS/ECI 混合部署,结合新的库存调度算法,提高单台物理机的资源利用率,降低 ECI 甚至整个弹性计算的成本。ECI 目前支持远比 ECS 更小的规格,这在一定程度上可以弥补目前物理机调度的资源碎片的缺陷。

ECI 的成本

ECI 的成本主要包含ECI 实例、网络和存储的使用费用。ECI 实例能够支持两种资源申请和计费模式。

模式一:根据 CPU/ 内存进行资源申请和计费。ECI 会利用 ECS 多个规格族的库存,保障资源的交付。例如:2C4G,会尝试使用 ECS ecs.c6.largeecs.sn1ne. largeecs.se1ne.large 等规格进行资源的交付。

模式二:根据 ECS 规格进行资源申请和计费,价格参考各地域 ECS 按量价格, 用户可以根据需要指定 ECS 规格族来使用各规格族的指定能力,例如:指定使用 ecs. sn1ne 规格族,来使用网络增强能力。网络的使用费用主要包括VPC 网络中的负载均衡设备、弹性公网IPprivateZone 等费用;存储的使用费用主要包括NASOSSEBS 快照等的使用费用。

ECI ECS 最大的不同就在于ECI 是按量秒级计费的,而不是ECS 常用的包年包月形式。ECI 只会收取用户从开始拉取业务镜像,到实例状态从Running 变成Succeed 或者Failed 之间的费用。ECI ECS 如图3-81 所示,用一个2C4G 的实例来说明,如果每天业务运行的时间正好是14 个小时的话,那么ECI 按量付费的成本和ECS 包月的成本是持平的。如果业务每天运行的时间小于14 个小时,那么按量的ECI 成本会比包月的ECS 更低。

除了帮助用户降低显性的使用成本,ECI 还能帮助用户降低隐性成本。Serverless 容器不向用户收取机器的资源成本,而直接按应用消耗的资源来收费。Serverless Kubernetes 提供了开箱即用的容器服务,大大降低了环境部署成本和时间, 同时阿里云在官网上提供了大量的帮助文档和最佳实践,大大降低了开发人员的使用门槛。

image.png


ECI 的启动速度

ECI 的弹性能力在很大程度上取决于ECI 并发创建时的启动速度,因此优化ECI

实例的并发启动速度非常关键。

这里以Nginx 容器的端到端的创建时间(如图3-82 所示)为例,除去实例启动占到的7% 的时间,资源调度的时间占到了43%,而镜像拉取的时间占到了50%

image.png

3-82  Nginx 容器端到端创建时间分析

容器在每次启动时,都会检查本地是否有相应的镜像,如果不存在,则会从远端的容器镜像仓库拉取镜像。在阿里云上的容器实例是运行在阿里云的安全沙箱内的,实例每次重建时都会销毁整个安全沙箱,其中也包括了已缓存到本地的镜像, 这就导致容器重建后依然会拉取镜像。为了减少拉取时间,业界主要有以下三种优化方法。

第一种方法是在所有的计算节点上都缓存基础镜像层,比如centosubuntu 等, 如果本地存储资源足够,还可以缓存部分常用的业务镜像。

第二种方法是采取P2P 传输的方式,从多台物理机并行拉取业务镜像的不同层,已缓存该业务镜像的物理机越多,并行拉取镜像的效率越高。

第三种方法是把系统盘和数据盘保存至分布式存储系统,借助存储系统的快照技术,在启动容器时,将快照克隆出的云盘动态挂载到容器中去。


经过大量的优化,目前ECI 启动时已经不需要从远端的容器镜像仓库拉取镜像, 并发创建实例的并行效率提升了数十倍。


相关实践学习
巧用云服务器ECS制作节日贺卡
本场景带您体验如何在一台CentOS 7操作系统的ECS实例上,通过搭建web服务器,上传源码到web容器,制作节日贺卡网页。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
19天前
|
Kubernetes Cloud Native 微服务
探索云原生技术:容器化与微服务架构的融合之旅
本文将带领读者深入了解云原生技术的核心概念,特别是容器化和微服务架构如何相辅相成,共同构建现代软件系统。我们将通过实际代码示例,探讨如何在云平台上部署和管理微服务,以及如何使用容器编排工具来自动化这一过程。文章旨在为开发者和技术决策者提供实用的指导,帮助他们在云原生时代中更好地设计、部署和维护应用。
|
2天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
15 4
|
24天前
|
开发框架 安全 开发者
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。
Docker 是一种容器化技术,支持开发者将应用及其依赖打包成容器,在不同平台运行而无需修改。本文探讨了 Docker 在多平台应用构建与部署中的作用,包括环境一致性、依赖管理、快速构建等优势,以及部署流程和注意事项,展示了 Docker 如何简化开发与部署过程,提高效率和可移植性。
53 4
|
24天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
55 3
|
26天前
|
运维 Kubernetes Docker
深入理解容器化技术:Docker与Kubernetes的协同工作
深入理解容器化技术:Docker与Kubernetes的协同工作
46 1
|
26天前
|
运维 Kubernetes Docker
深入理解容器化技术及其在微服务架构中的应用
深入理解容器化技术及其在微服务架构中的应用
54 1
|
27天前
|
安全 持续交付 Docker
深入理解并实践容器化技术——Docker 深度解析
深入理解并实践容器化技术——Docker 深度解析
50 2
|
21天前
|
人工智能 Kubernetes Cloud Native
荣获2024年AI Cloud Native典型案例,阿里云容器产品技术能力获认可
2024全球数字经济大会云·AI·计算创新发展大会,阿里云容器服务团队携手客户,荣获“2024年AI Cloud Native典型案例”。
|
26天前
|
Kubernetes Linux 开发者
深入探索容器化技术——Docker 的实战应用
深入探索容器化技术——Docker 的实战应用
74 0
|
27天前
|
持续交付 开发者 Docker
深入理解并实践容器化技术——Docker篇
深入理解并实践容器化技术——Docker篇
42 0

相关产品

  • 容器计算服务