写点什么

适用于 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:131206
用户头像

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

关注

评论

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

深入浅出Python——Python高级语法之函数

何极光

Python 函数 10月月更

【web 开发基础】PHP 快速入门(11)-PHP 运算符之运算符的优先级

迷彩

表达式 10月月更 web开发基础 PHP基础 运算符优先级

CSS学习笔记2

虾仁疙瘩汤

CSS css3 10月月更

Nginx反向代理是什么意思?如何配置Nginx反向代理?

wljslmz

nginx 反向代理 web服务器 10月月更

AntDesignPro使用electron构建桌面应用

乌龟哥哥

10月月更

C语言内存对齐问题

乌龟哥哥

C'语言 10月月更

css学习笔记3

虾仁疙瘩汤

CSS css3 10月月更

vue3.0 是如何变快的

乌龟哥哥

10月月更

【c++图论例题学习】【口袋的天空】【部落划分】

贤鱼很忙

c++ 图论 10月月更

深入浅出Python——Python基础语法全解

何极光

Python 基础 10月月更

威胁网络安全的主要因素

阿泽🧸

网络安全 10月月更

如何进行需求分析?

老张

软件工程 需求分析

leetcode 287. Find the Duplicate Number 寻找重复数 (中等)

okokabcd

LeetCode 数据结构与算法

力扣刷题训练

lovevivi

c 数据结构 10月月更

2022-10-25:在一个 2 * 3 的板上(board)有 5 块砖瓦,用数字 1~5 来表示, 以及一块空缺用 0 来表示。一次 移动 定义为选择 0 与一个相邻的数字(上下左右)进行交换.

福大大架构师每日一题

算法 rust 福大大

概述Spark主要特点

穿过生命散发芬芳

spark 10月月更

【web 开发基础】PHP的流程控制之单一分支结构-PHP 快速入门(12)

迷彩

10月月更 web开发基础 PHP基础 分支语句 if条件分支

Spring Boot「14」MVC 与前端控制器模式

Samson

Java spring 学习笔记 spring-boot 10月月更

liunx入门:Linux下基本指令

雪芙花

c++ Liunx 10月月更

C++从入门到精通(第十篇) :二叉搜索树

雪芙花

c++ 10月月更

Vue组件入门(十四)依赖注入

Augus

Vue 10月月更

2022年元宇宙应用场景发展趋势分析

易观分析

元宇宙

CSS基础1

虾仁疙瘩汤

CSS css3 10月月更

C++精通之路:map和set

雪芙花

c++ 10月月更

C# 关于程序退出问题学习

IC00

C# 学习 程序员 上位机 10月月更

SAP | 选择屏幕

暮春零贰

SAP 10月月更 屏幕

数据湖(十一):Iceberg表数据组织与查询

Lansonli

数据湖 10月月更

【c++图论例题学习】洛谷p1991 无线通讯网-思路详解

贤鱼很忙

c++ 图论 10月月更

【c++算法篇】--图论之克鲁斯卡尔

贤鱼很忙

c++ 图论 10月月更 克鲁斯卡尔

Commit之后发生了什么事情

我不吃六安茶

MySQL 事务

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