2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

适用于 EBS CSI 驱动程序的 EKS 支持

  • 2019-09-18
  • 本文字数:2004 字

    阅读完需:约 7 分钟

适用于 EBS CSI 驱动程序的 EKS 支持

今天,我们宣布推出适用于 EBS 容器存储接口驱动程序的 EKS 支持。这项举措的目的是为了在 Kubernetes 等容器编排系统和 AWS 等存储供应商之间建立统一的存储接口。

Kubernetes 中的存储的历史

按照最初的设想,容器非常适合无状态应用程序。但容器并未预置持久性的存储,因此无法支持有状态的工作负载。而许多应用程序在设计时并未考虑容器化,因此为了支持将各种类型的应用程序都迁移到云中,容器编排程序推出了对存储的支持,从而让有状态应用程序成为可能。


Kubernetes 率先通过树内卷插件的方式推出了对有状态工作负载的支持。树内卷插件是指插件代码是核心 Kubernetes 代码的组成部分并随 Kubernetes 二进制代码包交付。但这种模式被证明问题极大,因为希望为 Kubernetes 增加对其存储系统的支持(甚至只是修复现有卷插件中的某个漏洞)的供应商将不得不与 Kubernetes 的发布进程保持同步。由于这一问题的存在,容器存储接口 (CSI) 应运而生。这是一种向 Kubernetes 等容器编排系统上的容器化工作负载暴露任意块和文件存储系统的标准。Kubernetes v1.9 以内测版的方式推出了 CSI 支持,Kubernetes v1.10 推出公测版,Kubernetes v1.13 正式发布。随着 CSI 规范的出现,容器编排系统和存储提供商能够以模块化的方式独立演进。借助 CSI 驱动程序,Kubernetes 上游发布周期与 CSI 驱动程序发布周期将会脱钩,从而让您受益。用户无需等待新的 Kubernetes 版本发布即可升级至最新版本的驱动程序。

Amazon Elastic Block Store (EBS)

Amazon EBS 是一种云块存储服务,通过它可以从 EC2 实例直接访问专用存储卷。最初推出的 EBS 支持是 Kubernetes 中的一种树内卷插件。随着 CSI 规范的发布,我们开始开发兼容 Amazon EBS 的驱动程序。我们以开源的方式在 GitHub 中提供 EBS CSI 驱动程序(包含在 kubernetes-sigs 中)。从 Kubernetes 版本 1.12(驱动程序版本 0.2,使用 CSI 0.3 规范)和版本 1.13(驱动程序版本 0.3,使用 CSI 1.0 规范)开始,此驱动程序都可用于在 AWS 上自我管理的 Kubernetes 安装。但在版本 1.14 以前,CSINodeInfo 和 CSIBlockVolume 等功能属于 Kubernetes 的内测功能,因此还不被 Amazon EKS 支持。现在,借助 适用于 Kubernetes 版本 1.14 的 EKS 支持,用户可以将 EBS CSI 驱动程序(版本 v0.4.0 或以上)安装到他们的 EKS 1.14 集群中。

EBS CSI 驱动程序操作

EBS CSI 驱动程序将按照 CSI 规范的要求,执行将卷预置、附加和挂载到 Pod 中的基本操作,以及移除卷的反向操作。为 Pod 预置存储的现行树内工作流保持不变,您只需定义将作为预置程序使用 CSI 驱动程序的新存储类即可。以下是一个存储类清单文件的示例:


kind: StorageClassapiVersion: storage.k8s.io/v1 metadata:  name: csi-sc provisioner: ebs.csi.aws.comvolumeBindingMode: WaitForFirstConsumer
复制代码


此 CSI 驱动程序支持当前树内 EBS 卷驱动程序支持的所有存储类参数。参数包括 type、csi.storage.k8s.io/fsType、iopsPerGB、encrypted 和 kmsKeyId。 请注意,zone/zones 参数未包含在内,因为它已在 kubernetes v1.12 中被 allowedTopologies 参数代替。如果您构建需要在不同的可用区预置卷以便 Pod 访问的多区应用程序,可以将 volumeBindingMode 设置为 WaitForFirstConsumer,从而开启卷调度功能。


通过四个步骤即可将 EBS CSI 驱动程序用于 Kubernetes 集群:


1.向工作线程节点授予恰当的权限。


2.安装驱动程序:kubectl apply -k “github.com/kubernetes-sigs/aws-ebs-csi-driver/deploy/kubernetes/overlays/stable/?ref=master


3.使用与以上类似的示例清单文件创建存储类。


4.创建一个持久卷声明或持久卷,并使用与树内卷插件相同的工作流消费该卷。


有关安装说明的更多详细信息,请参阅 EKS 文档。有关 EBS CSI 驱动程序的更多详细信息,请参阅 aws-ebs-csi-driver GitHub 页面的 README 文件。

限制

要连接到 EBS 卷,在 EKS 上的 Pod 内运行的应用程序必须位于该 EBS 卷所在可用区的某个节点内。目前,一个 EBS 卷一次只能挂载到一个 Kubernetes 节点。

迁移到 EBS CSI 驱动程序

在 Kubernetes 1.14 中,CSIMigrationAWS 作为一项 Kubernetes 内测功能推出,增加了支持 shim 和翻译逻辑将卷操作从 EBS 树内插件路由到 EBS CSI 插件的功能。由于它的内测性质,此功能还不能用于 EKS 中的生产用途。我们也在向 Kubernetes 的上游做贡献,以在未来的发布中将此功能从内测版升级到公测版。目前,现有树内 EBS 插件仍获支持。

后续工作

有关 EBS CSI 插件的后续工作将集中在多个主题上,包括内测功能的稳定(例如卷容量调整和卷快照)、使驱动程序支持从树内 EBS 插件进行迁移、增加性能测试等等。如果您希望了解更多详细信息,可以在 GitHub 上查看我们的里程碑。我们衷心欢迎大家的反馈,期待你们的宝贵贡献!


本文转载自 AWS 博客。


原文链接:


https://amazonaws-china.com/cn/blogs/china/eks-support-ebs-csi-driver/


2019-09-18 15:131218
用户头像

发布了 1945 篇内容, 共 164.0 次阅读, 收获喜欢 81 次。

关注

评论

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

为什么企业越大,越难实现数字化

积木链小链

企业管理 数字化 制造业 ERP

Go 并发控制:singleflight 详解

江湖十年

优雅的@ObservedV2和@Trace装饰器

威哥爱编程

HarmonyOS HarmonyOS框架 HarmonyOS NEXT HarmonyOS5.0

使用低代码平台,让复杂的应用开发变得更轻松

JeeLowCode低代码平台

低代码 低代码前端 低代码,

AI口语陪练APP的主要功能

北京木奇移动技术有限公司

软件外包公司 AI口语陪练 AI口语练习

「阿里巴巴」独投的人形机器人公司,再获“产业派”大佬独投!!

机器人头条

阿里巴巴 投资 大模型 人形机器人 具身智能

成都某自研公司一面

王中阳Go

Go 面试题

中层干部如何管理不合作的员工

易成研发中心

企业管理

又有多位自动驾驶技术“大牛”,进入具身智能机器人赛道

机器人头条

自动驾驶 机器人 大模型 具身智能 人形机器他

2024华为云开源开发者论坛顺利召开,引领开放创新,共筑数智未来

新消费日报

数据驱动商业智能决策 引领品牌迈向高利润之路

第七在线

在SAP Fiori界面上的VF03事务

SAP虾客

SAP Fiori SAP S4HANA VF03

这个小游戏SDK突破微信可运行在任何的app

Onegun

小游戏 小游戏引擎 小游戏运营 小游戏平台

从报表到可视化,基于开源Superset实现数据管理升级的实践

华为云开发者联盟

Kubernetes Apache Superset CCE #开源

高成长、高潜力、高社区影响!镜舟科技入选 2024 中国新锐技术先锋企业

镜舟科技

开源 分析型数据库 StarRocks SegmentFault

域控制器升级的先决条件验证失败怎么办?

运维有小邓

windows AD域 IT运维管理

公开课 | 提高测试用例编写效率,掌握经典用例设计技巧!

测试人

软件测试

10个案例详解AnimatableExtend装饰器定义可动画属性

威哥爱编程

HarmonyOS HarmonyOS NEXT HarmonyOS5.0

如何进行知识管理

易成研发中心

知识管理 知识管理系统 知识管理软件

在SAP Fiori界面上的ME53N事务

SAP虾客

SAP S/4HANA SAP Fiori ME53N

媒体集团建设融媒体中心,特色化实践不断

FinFish

小程序容器 小程序技术 智慧传媒 融媒体中心 媒体转型

测试匠谈 | 微信H5兼容性测试理论和实践经验

优测云服务平台

测试 兼容性测试 微信H5

适用于 EBS CSI 驱动程序的 EKS 支持_服务革新_亚马逊云科技 (Amazon Web Services)_InfoQ精选文章