本文属于机器翻译版本。若本译文内容与英语原文存在差异,则一律以英文原文为准。
使用 Amazon 创建 Amazon ECS 任务定义并在EC2实例上挂载文件系统 EFS
由 Durga Prasad Cheepuri 创作 () AWS
环境:PoC 或试点 | 技术:容器和微服务; CloudNative;管理和治理;存储和备份;Web 和移动应用程序 | AWS服务:亚马逊ECS;亚马逊 EFS |
Summary
此模式提供了创建亚马逊弹性容器服务 (AmazonECS) 任务定义的代码示例和步骤,该任务定义在亚马逊云服务 (EC2) 云中的亚马逊弹性计算云 (AmazonAWS) 实例上运行,同时使用亚马逊弹性文件系统 (AmazonEFS) 在这些EC2实例上挂载文件系统。使用 Amazon 的 Amazon ECS 任务EFS会自动挂载您在任务定义中指定的文件系统,并使这些文件系统可供该AWS区域所有可用区的任务容器使用。
为了满足您的永久存储和共享存储需求,您可以EFS同时使用 Amazon ECS 和 Amazon。例如,您可以使用 Amazon EFS 存储应用程序的永久用户数据和应用程序数据,活动容器和备用ECS容器对在不同的可用区中运行,以实现高可用性。您还可以使用 Amazon EFS 存储共享数据,ECS容器和分布式任务工作负载可以并行访问这些数据。
要将 Amazon EFS 与 Amazon 配合使用ECS,您可以在任务定义中添加一个或多个卷定义。卷定义包括亚马逊EFS文件系统 ID、接入点 ID 以及传输过程中AWS身份和访问管理 (IAM) 授权或传输层安全 (TLS) 加密的配置。您可以在任务定义中使用容器定义来指定容器运行时挂载的任务定义卷。当使用 Amazon EFS 文件系统的任务运行时,Amazon 会ECS确保文件系统已挂载并可供需要访问的容器使用。
先决条件和限制
先决条件
一个活跃的AWS账户
带有虚拟专用网络 (VPC) 端点或路由器的虚拟私有云 (VPN)
(推荐)亚马逊ECS容器代理 1.38.0 或更高版本,以便与亚马逊EFS接入点和IAM授权功能兼容(有关更多信息,请参阅AWS博客文章《亚马逊新增功能 EFS — IAM 授权和接入
点》。)
限制
1.35.0 之前的亚马逊ECS容器代理版本不支持使用EC2启动类型的任务的亚马逊EFS文件系统。
架构
下图显示了一个应用程序的示例,该应用程序使用 Amazon ECS 创建任务定义并在ECS容器中的EC2实例上挂载 Amazon EFS 文件系统。
图表显示了以下工作流:
创建 Amazon EFS 文件系统。
创建带有容器的任务定义。
配置容器实例以挂载 Amazon EFS 文件系统。任务定义引用卷挂载,因此容器实例可以使用 Amazon EFS 文件系统。ECS任务可以访问同一 Amazon EFS 文件系统,无论这些任务是在哪个容器实例上创建的。
使用任务定义的三个实例创建一个 Amazon ECS 服务。
技术堆栈
Amazon EC2
Amazon ECS
Amazon EFS
工具
亚马逊 EC2 — 亚马逊弹性计算云 (AmazonEC2) 在AWS云中提供可扩展的计算容量。您可以根据需要使用 Amazon EC2 启动任意数量或数量的虚拟服务器,也可以进行横向扩展或扩展。
Amaz on ECS — Amazon 弹性容器服务 (AmazonECS) 是一项高度可扩展、快速的容器管理服务,用于在集群上运行、停止和管理容器。您可以在由 Far AWS gate 管理的无服务器基础架构上运行任务和服务。或者,为了更好地控制您的基础架构,您可以在自己管理的EC2实例集群上运行任务和服务。
亚马逊 EFS — Amazon Elastic File System(亚马逊EFS)提供了一个简单、可扩展、完全托管的弹性NFS文件系统,用于AWS云服务和本地资源。
AWSCLI— AWS 命令行界面 (AWSCLI) 是一个开源工具,用于通过命令行外壳中的命令与AWS服务进行交互。只需最少的配置,您就可以在AWSCLI命令提示符下运行命令,实现与基于浏览器的AWS管理控制台提供的功能等同的功能。
操作说明
任务 | 描述 | 所需技能 |
---|---|---|
使用AWS管理控制台创建 Amazon EFS 文件系统。 |
| AWS DevOps |
任务 | 描述 | 所需技能 |
---|---|---|
使用 Amazon EFS 文件系统创建任务定义。 | 使用全新 Amazon ECS 控制台或具有以下配置的经典 Amazon ECS 控制台创建任务定义:
| AWS DevOps |
使用创建任务定义AWSCLI。 |
| AWS DevOps |
相关资源
附件
要访问与此文档相关联的其他内容,请解压以下文件:attachment.zip