使用 Terraform 建立叢集並部署工作負載
Kubernetes 叢集可為應用程式提供運算、儲存空間、網路和其他服務,類似於虛擬資料中心。在 Kubernetes 中執行的應用程式及其相關服務稱為「工作負載」。
本教學課程會使用 Terraform 快速設定並執行 Google Kubernetes Engine 叢集和範例工作負載。接著,您可以在 Google Cloud 控制台中探索工作負載,然後繼續深入學習,或是開始規劃及建立自己的正式叢集。本教學課程假設您已熟悉 Terraform。
如要在 Google Cloud 控制台中設定範例叢集和工作負載,請參閱「在 Google Cloud 控制台中建立叢集」。
事前準備
請依照下列步驟啟用 Kubernetes Engine API:
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
- 
      Install the Google Cloud CLI. 
- 
          如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 
- 
        如要初始化 gcloud CLI,請執行下列指令: gcloud init
- 
  
  
    Create or select a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 - 
        Create a Google Cloud project: gcloud projects create PROJECT_ID Replace PROJECT_IDwith a name for the Google Cloud project you are creating.
- 
        Select the Google Cloud project that you created: gcloud config set project PROJECT_ID Replace PROJECT_IDwith your Google Cloud project name.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the GKE API: Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable container.googleapis.com 
- 
      Install the Google Cloud CLI. 
- 
          如果您使用外部識別資訊提供者 (IdP),請先 使用聯合身分登入 gcloud CLI。 
- 
        如要初始化 gcloud CLI,請執行下列指令: gcloud init
- 
  
  
    Create or select a Google Cloud project. Roles required to select or create a project - Select a project: Selecting a project doesn't require a specific IAM role—you can select any project that you've been granted a role on.
- 
      Create a project: To create a project, you need the Project Creator
      (roles/resourcemanager.projectCreator), which contains theresourcemanager.projects.createpermission. Learn how to grant roles.
 - 
        Create a Google Cloud project: gcloud projects create PROJECT_ID Replace PROJECT_IDwith a name for the Google Cloud project you are creating.
- 
        Select the Google Cloud project that you created: gcloud config set project PROJECT_ID Replace PROJECT_IDwith your Google Cloud project name.
 
- 
  
    Verify that billing is enabled for your Google Cloud project. 
- 
  
  
    
      Enable the GKE API: Roles required to enable APIs To enable APIs, you need the Service Usage Admin IAM role ( roles/serviceusage.serviceUsageAdmin), which contains theserviceusage.services.enablepermission. Learn how to grant roles.gcloud services enable container.googleapis.com 
- 
    
        Grant roles to your user account. Run the following command once for each of the following IAM roles: roles/container.admin, roles/compute.networkAdmin, roles/iam.serviceAccountUsergcloud projects add-iam-policy-binding PROJECT_ID --member="user:USER_IDENTIFIER" --role=ROLE Replace the following: - PROJECT_ID: Your project ID.
- USER_IDENTIFIER: The identifier for your user account. For example,- myemail@example.com.
- ROLE: The IAM role that you grant to your user account.
 
- 從 Google Cloud 控制台啟動 Cloud Shell 工作階段,方法是按一下 Cloud Shell 啟用圖示「啟用 Cloud Shell」  。系統會在 Google Cloud 控制台的底部窗格啟動工作階段。 。系統會在 Google Cloud 控制台的底部窗格啟動工作階段。- 與這部虛擬機器相關聯的服務憑證是自動產生,因此不必設定或下載服務帳戶金鑰。 
- 執行指令前,請先使用下列指令,在 gcloud CLI 中設定預設專案: - gcloud config set project PROJECT_ID- 將 - PROJECT_ID替換為專案 ID。
- 複製 GitHub 存放區: - git clone https://github.com/terraform-google-modules/terraform-docs-samples.git --single-branch
- 變更為工作目錄: - cd terraform-docs-samples/gke/quickstart/autopilot
- 查看 - cluster.tf檔案:- cat cluster.tf- 輸出內容類似如下 - 這個檔案說明下列資源: - google_compute_network:已啟用內部 IPv6 的虛擬私有雲網路。
- google_compute_subnetwork:雙堆疊子網路。
- google_container_cluster:位於- us-central1的雙堆疊 Autopilot 模式叢集。- deletion_protection設定可控制您是否能使用 Terraform 刪除這個叢集。如果您將- deletion_protection欄位中的值設為- false,Terraform 就能刪除叢集。詳情請參閱- google_container_cluster參考資料。
 
- 查看 - app.tf檔案:- cat app.tf- 輸出結果會與下列內容相似: - 這個檔案說明下列資源: - 使用範例容器映像檔的部署作業。
- LoadBalancer 類型的服務。這項服務會透過通訊埠 80 公開 Deployment。
 
- 在 - cluster.tf中,將- ipv6_access_type從- INTERNAL變更為- EXTERNAL。- ipv6_access_type = "EXTERNAL"
- 在 - app.tf中,移除- networking.gke.io/load-balancer-type註解,設定外部負載平衡器。- annotations = { "networking.gke.io/load-balancer-type" = "Internal" # Remove this line }
- 在 Cloud Shell 中執行下列指令,確認 Terraform 可供使用: - terraform- 畫面會顯示如下的輸出內容: - Usage: terraform [global options] <subcommand> [args] The available commands for execution are listed below. The primary workflow commands are given first, followed by less common or more advanced commands. Main commands: init Prepare your working directory for other commands validate Check whether the configuration is valid plan Show changes required by the current configuration apply Create or update infrastructure destroy Destroy previously-created infrastructure
- 初始化 Terraform: - terraform init
- 規劃 Terraform 設定: - terraform plan
- 套用 Terraform 設定 - terraform apply- 系統提示時,請輸入 - yes確認動作。這個指令可能需要幾分鐘才能完成。輸出結果會與下列內容相似:- Apply complete! Resources: 6 added, 0 changed, 0 destroyed.
- 前往 Google Cloud 控制台的「Workloads」(工作負載) 頁面: 
- 按一下 - example-hello-app-deployment工作負載。系統隨即會顯示「Pod 詳細資料」頁面。這個頁面會顯示 Pod 的相關資訊,例如註解、在 Pod 上執行的容器、公開 Pod 的服務,以及 CPU、記憶體和磁碟用量等指標。
- 前往 Google Cloud 控制台的「Services & Ingress」(服務與 Ingress) 頁面: 
- 按一下 - example-hello-app-loadbalancerLoadBalancer 服務。系統隨即會顯示「服務詳細資料」頁面。這個頁面會顯示 Service 的相關資訊,例如與 Service 相關聯的 Pod,以及 Service 使用的通訊埠。
- 在「外部端點」部分,按一下「IPv4 連結」或「IPv6 連結」,即可在瀏覽器中查看服務。輸出結果會與下列內容相似: - Hello, world! Version: 2.0.0 Hostname: example-hello-app-deployment-5df979c4fb-kdwgr
- 在 Cloud Shell 中執行下列指令,刪除 Terraform 資源: - terraform destroy --auto-approve
- 刪除防火牆規則: - gcloud compute firewall-rules list --filter="NETWORK:example-network" --format="table[no-heading](name)" | xargs gcloud --quiet compute firewall-rules delete
- 重新執行 Terraform 指令: - terraform destroy --auto-approve
- 在 Google Cloud 控制台中探索叢集和工作負載,瞭解您部署的一些重要工作負載設定和資源。 
- 如要進一步瞭解如何設定及使用 Terraform 和 GKE,請參閱「Terraform 支援 GKE」。 
- 請參閱更深入的學習路徑:可擴充的應用程式。 
- 如要瞭解如何開始管理實際叢集,請參閱叢集管理總覽。 
準備環境
在本教學課程中,您將使用 Cloud Shell 管理Google Cloud上託管的資源。Cloud Shell 已預先安裝本教學課程所需的軟體,包括 Terraform、kubectl 和 Google Cloud CLI。
查看 Terraform 檔案
Google Cloud 供應商是外掛程式,可讓您使用 Terraform 管理及佈建 Google Cloud 資源。這個供應商可做為 Terraform 設定與 Google Cloud API 之間的橋樑,讓您以宣告方式定義基礎架構資源,例如虛擬機器和網路。
本教學課程的叢集和範例應用程式,是在使用 Google Cloud 和 Kubernetes 供應商的兩個 Terraform 檔案中指定。
(選用) 將應用程式公開發布到網際網路
範例的 Terraform 檔案說明具有內部 IP 位址的應用程式,該應用程式只能從與範例應用程式相同的虛擬私有雲 (VPC) 存取。如要從網際網路 (例如從筆電) 存取執行中的示範應用程式網頁介面,請先修改 Terraform 檔案來建立公開 IP 位址,再建立叢集。您可以直接在 Cloud Shell 中使用文字編輯器,或使用 Cloud Shell 編輯器執行這項操作。
如要將示範應用程式公開發布到網際網路,請按照下列步驟操作:
建立叢集並部署應用程式
確認叢集運作正常
請執行下列操作,確認叢集運作正常:
清除所用資源
如要避免系統向您的 Google Cloud 帳戶收取本頁面所用資源的費用,請刪除含有這些資源的 Google Cloud 專案。
如果您打算參加其他教學課程或進一步探索範例,請先完成這些作業,再執行這個清除步驟。
排解清除錯誤
如果看到類似 The network resource 'projects/PROJECT_ID/global/networks/example-network' is already being used by 'projects/PROJECT_ID/global/firewalls/example-network-yqjlfql57iydmsuzd4ot6n5v' 的錯誤訊息,請按照下列步驟操作: