使用 Amazon EFS 在 EC2 執行個體上建立 Amazon ECS 任務定義並掛載檔案系統 - AWS 方案指引

本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。

使用 Amazon EFS 在 EC2 執行個體上建立 Amazon ECS 任務定義並掛載檔案系統

由 Durga Prasad Cheepuri (AWS) 建立

Summary

此模式提供程式碼範例和步驟,以建立在 Amazon Web Services (AWS) Cloud 中 Amazon Elastic Compute Cloud (Amazon EC2) 執行個體上執行的 Amazon Elastic Container Service (Amazon ECS) 任務定義,同時使用 Amazon Elastic File System (Amazon EFS) 在這些 EC2 執行個體上掛載檔案系統。使用 Amazon EFS 的 Amazon ECS 任務會自動掛載您在任務定義中指定的檔案系統,並將這些檔案系統提供給 AWS 區域中所有可用區域中的任務容器。

為了滿足您的持久性儲存和共用儲存需求,您可以同時使用 Amazon ECS 和 Amazon EFS。例如,您可以使用 Amazon EFS,透過在不同可用區域中執行的作用中和待命 ECS 容器對來存放應用程式的持久性使用者資料和應用程式資料,以實現高可用性。您也可以使用 Amazon EFS 來存放共用資料,以供 ECS 容器和分散式任務工作負載平行存取。

若要將 Amazon EFS 與 Amazon ECS 搭配使用,您可以將一或多個磁碟區定義新增至任務定義。磁碟區定義包含 Amazon EFS 檔案系統 ID、存取點 ID,以及傳輸中 AWS Identity and Access Management (IAM) 授權或 Transport Layer Security (TLS) 加密的組態。您可以使用任務定義中的容器定義來指定在容器執行時要掛載的任務定義磁碟區。當使用 Amazon EFS 檔案系統的任務執行時,Amazon ECS 會確保檔案系統已掛載,並可供需要存取的容器使用。

先決條件和限制

先決條件

限制

  • 1.35.0 之前的 Amazon ECS 容器代理程式版本不支援使用 EC2 啟動類型的任務使用 Amazon EFS 檔案系統。

架構

下圖顯示使用 Amazon ECS 在 ECS 容器中的 EC2 執行個體上建立任務定義和掛載 Amazon EFS 檔案系統的應用程式範例。

AWS 雲端 architecture showing ECS task definition, ECS service, and EFS file system interaction.

該圖顯示以下工作流程:

  1. 建立 Amazon EFS 檔案系統。

  2. 使用容器建立任務定義。

  3. 設定容器執行個體以掛載 Amazon EFS 檔案系統。任務定義參考磁碟區掛載,因此容器執行個體可以使用 Amazon EFS 檔案系統。ECS 任務可存取相同的 Amazon EFS 檔案系統,無論這些任務是在哪個容器執行個體上建立。

  4. 使用任務定義的三個執行個體建立 Amazon ECS 服務。

技術堆疊

  • Amazon EC2

  • Amazon ECS

  • Amazon EFS

工具

  • Amazon EC2 – Amazon Elastic Compute Cloud (Amazon EC2) 在 AWS 雲端中提供可擴展的運算容量。您可以使用 Amazon EC2 視需要啟動任意數量或任意數量的虛擬伺服器,也可以向外擴展或向內擴展。

  • Amazon ECS – Amazon Elastic Container Service (Amazon ECS) 是一種高度可擴展的快速容器管理服務,用於執行、停止和管理叢集上的容器。您可以在 AWS Fargate 管理的無伺服器基礎設施上執行任務和服務。或者,若要進一步控制您的基礎設施,您可以在您管理的 EC2 執行個體叢集上執行任務和服務。

  • Amazon EFS – Amazon Elastic File System (Amazon EFS) 提供簡單、可擴展、全受管的彈性 NFS 檔案系統,可與 AWS 雲端服務和內部部署資源搭配使用。

  • AWS CLI – AWS Command Line Interface (AWS CLI) 是一種開放原始碼工具,可透過命令列 shell 中的命令與 AWS 服務互動。透過最少的組態,您可以從命令提示中執行 AWS CLI 命令,該命令會實作與瀏覽器型 AWS 管理主控台所提供功能相同的功能。

史詩

任務描述所需的技能
使用 AWS 管理主控台建立 Amazon EFS 檔案系統。
  1. 注意

    建立 Amazon EFS 檔案系統,然後選擇包含您容器的 VPC。:如果您使用不同的 VPC,請設定 VPC 對等互連

  2. 請注意檔案系統 ID。

AWS DevOps
任務描述所需的技能
使用 Amazon EFS 檔案系統建立任務定義。

使用新的 Amazon ECS 主控台具有下列組態的傳統 Amazon ECS 主控台來建立任務定義:

  • 如果您使用新的主控台,請選擇應用程式環境Amazon EC2 執行個體。如果您使用傳統主控台,請選擇 EC2 作為啟動類型。

  • 新增磁碟區。輸入磁碟區的名稱,選擇磁碟區類型的 EFS,然後選擇您先前記下的檔案系統 ID。針對根目錄,選擇您要在 Amazon ECS 容器主機上託管的 Amazon EFS 檔案系統路徑。

AWS DevOps
使用 AWS CLI 建立任務定義。
  1. 若要為任務定義建立具有輸入參數預留位置的 JSON 範本,請執行下列命令:

    aws ecs register-task-definition --generate-cli-skeleton
  2. 若要使用 JSON 範本建立任務定義,請執行下列命令:

    aws ecs register-task-definition --cli-input-json file://<path_to_your_json_file>
  3. 注意

    根據 task_definition_parameters.json 檔案 (已連接),在 JSON 範本中輸入輸入參數。:如需輸入參數的詳細資訊,請參閱任務定義參數 (Amazon ECS 文件) 和 register-task-definition (AWS CLI 命令參考)。

AWS DevOps

相關資源

附件

若要存取與本文件相關聯的其他內容,請解壓縮下列檔案: attachment.zip