釋放 AI 的強大力量

100 萬免費代幣

88% 價格優惠

立即啟用
本文由簡體中文內容自動轉碼而成。阿里雲不保證此自動轉碼的準確性、完整性及時效性。本文内容請以簡體中文版本為準。

在Cloud Shell中使用Terraform建立ENS執行個體

更新時間:2025-03-12 20:35

阿里雲邊緣節點服務ENS產品已經接入Terraform,可以通過Terraform來實現快速配置。本文介紹如何在Cloud Shell中使用Terraform建立ENS執行個體。

說明

當前範例程式碼支援一鍵運行,您可以直接運行代碼。一鍵運行

前提條件

  • 由於阿里雲帳號(主帳號)具有資源的所有許可權,一旦發生泄露將面臨重大風險。建議您使用RAM使用者,並為該RAM使用者建立AccessKey,具體操作方式請參見建立RAM使用者建立AccessKey

  • 使用以下樣本為RAM使用者授權,需要為該RAM使用者授予以下許可權:。具體操作方式請參見為RAM使用者授權

    {
      "Version": "1",
      "Statement": [
        {
          "Effect": "Allow",
          "Action": "ens:*",
          "Resource": "*"
        },
        {
          "Effect": "Allow",
          "Action": [
            "bssapi:*",
            "bss:*",
            "efc:*"
          ],
          "Resource": "*"
        }
      ]
    }
  • 準備Terraform運行環境,您可以選擇以下任一方式來使用Terraform。

    Explorer中使用Terraform:阿里雲提供了Terraform的線上運行環境,您無需安裝Terraform,登入後即可線上使用和體驗Terraform。適用於零成本、快速、便捷地體驗和調試Terraform的情境。

    Cloud Shell:阿里雲Cloud Shell中預裝了Terraform的組件,並已配置好身份憑證,您可直接在Cloud Shell中運行Terraform的命令。適用於低成本、快速、便捷地訪問和使用Terraform的情境。

    在本地安裝和配置Terraform:適用於網路連接較差或需要自訂開發環境的情境。

重要

請確保Terraform版本不低於v0.12.28。如需檢查現有版本,請運行terraform --version命令。

說明

本教程樣本包含的部分資源會產生一定費用,請在不需要時及時進行退訂。

使用的資源

alicloud_ens_instance:建立ENS執行個體。

使用Terraform建立ENS執行個體

操作步驟

本樣本將建立ENS執行個體。

  1. 建立一個工作目錄,並且在工作目錄中建立以下名為main.tf的設定檔。main.tfTerraform主檔案,定義了將要部署的資源。

    variable "region" {
      default = "cn-hangzhou"
    }
    provider "alicloud" {
      region = var.region
    }
    variable "image_id" {
      default = "win2022_21H2_x64_dtc_zh-cn_40G_alibase_20211116"
    }
    variable "instance_type" {
      default = "ens.sn1.small"
    }
    variable "internet_charge_type" {
      default = "BandwidthByDay"
    }
    # ENS執行個體資源
    resource "alicloud_ens_instance" "instance" {
      # (可選, Int, 自v1.208.0起可用) 資源購買時間長度。設定方法:如果PeriodUnit設定為Day,Period只能設定為3;如果PeriodUnit設定為Month,Period可以設定為1-9,12。
      period = 1
      # 資料盤
      #data_disk {
        # 資料盤大小,單位:GB
        #size     = 20
        # 資料盤類型。可選值:cloud_efficiency(高效雲端硬碟)、cloud_ssd(SSD雲端硬碟)、local_hdd(本地HDD磁碟)、local_ssd(本地SSD磁碟)。
        #category = "cloud_efficiency"
      #}
      #  (可選, 自v1.208.0起可用) 是否分配公網IP標識符。值:true(預設):分配、false:不分配。
      public_ip_identification   = true  
      # 購買資源的時間單位。值:Month(預設):按月購買、Day:按天購買。
      period_unit                = "Month" 
      # 調度策略。可選值:Concentrate(節點級調度)、Disperse(地區調度)。
      scheduling_strategy        = "Disperse" 
      # 調度層級,通過它進行節點級調度或地區調度。可選值:Node-level scheduling(節點級調度):Region;Regional scheduling(地區調度):Big(地區)、Middle(省)、Small(市)。
      schedule_area_level        = "Big"  
      # 執行個體的鏡像ID。arm版本卡不能填寫。
      image_id                   = var.image_id
      # 執行個體規格。
      instance_type              = var.instance_type
      # 執行個體的主機名稱
      host_name                  = "Host80" 
      # 執行個體密碼
      password                   = "Ens-test@" 
      # 執行個體頻寬計費方式。如果首次購買時可以選擇計費方式,則後續該欄位的值將按照首次選擇的計費方式進行處理。可選值:BandwidthByDay(按日峰值頻寬)、95bandwidthbymonth(95峰值頻寬)。
      internet_charge_type       = var.internet_charge_type
      #  執行個體付款條件。自v1.230.0起可以修改payment_type。可選值:Subscription(預付費,訂用帳戶)、PayAsYouGo(隨用隨付)。
      payment_type              = "PayAsYouGo"
      # 電訊廠商,為地區調度所需。可選值:cmcc(移動)unicom(聯通)telecom(電信)
      carrier                   = "cmcc"
      # 調度價格策略。如果未填,將預設為低價優先。
      scheduling_price_strategy  = "PriceLowPriority"
      # 最大公網頻寬
      internet_max_bandwidth_out = 1
      # 節點ID。當ScheduleAreaLevel為Region時,EnsRegionId是必需的。當ScheduleAreaLevel為Big、Middle、Small時,EnsRegionId無效。
      # ens_region_id              = "cn-zhengzhou-telecom"  
      # 添加 net_district_code 參數
      net_district_code             = "100102" # 請根據實際規範調整
      # 系統硬碟規格
      system_disk {
        size = 40
      }
    }
  2. 執行以下命令,初始化Terraform運行環境。

    terraform init

    返回如下資訊,表示Terraform初始化成功。

    Initializing the backend...
    
    Initializing provider plugins...
    - Reusing previous version of hashicorp/alicloud from the dependency lock file
    - Using previously-installed hashicorp/alicloud v1.231.0
    
    Terraform has been successfully initialized!
    
    You may now begin working with Terraform. Try running "terraform plan" to see
    any changes that are required for your infrastructure. All Terraform commands
    should now work.
    
    If you ever set or change modules or backend configuration for Terraform,
    rerun this command to reinitialize your working directory. If you forget, other
    commands will detect it and remind you to do so if necessary.
  3. 建立執行計畫,並預覽變更。

    terraform plan
  4. 執行以下命令,建立ENS執行個體。

    terraform apply

    在執行過程中,根據提示輸入yes並按下Enter鍵,等待命令執行完成,若出現以下資訊,則表示ENS執行個體建立成功。

    Plan: 1 to add, 0 to change, 0 to destroy.
    
    Do you want to perform these actions?
      Terraform will perform the actions described above.
      Only 'yes' will be accepted to approve.
    
      Enter a value: yes
    
    alicloud_ens_instance.instance: Creating...
    alicloud_ens_instance.instance: Still creating... [10s elapsed]
    alicloud_ens_instance.instance: Still creating... [20s elapsed]
    
    ...
    
    alicloud_ens_instance.instance: Still creating... [11m30s elapsed]
    alicloud_ens_instance.instance: Creation complete after 11m31s [id=i-5495sqdyatehco3teqtls****]
    
    Apply complete! Resources: 1 added, 0 changed, 0 destroyed.
  5. 驗證結果

    執行terraform show命令
    登入邊緣節點服務ENS控制台

    您可以使用以下命令查詢Terraform已建立的資來源詳細資料:

    terraform show

    image

    登入邊緣節點服務ENS控制台,查看已建立的執行個體。

    image

清理資源

當您不再需要上述通過Terraform建立或管理的資源時,請運行以下命令以釋放資源。關於terraform destroy的更多資訊,請參見常用命令

terraform destroy

完整樣本

說明

當前範例程式碼支援一鍵運行,您可以直接運行代碼。一鍵運行

範例程式碼

variable "region" {
  default = "cn-hangzhou"
}
provider "alicloud" {
  region = var.region
}
variable "image_id" {
  default = "win2022_21H2_x64_dtc_zh-cn_40G_alibase_20211116"
}
variable "instance_type" {
  default = "ens.sn1.small"
}
variable "internet_charge_type" {
  default = "BandwidthByDay"
}
# ENS執行個體資源
resource "alicloud_ens_instance" "instance" {
  # (可選, Int, 自v1.208.0起可用) 資源購買時間長度。設定方法:如果PeriodUnit設定為Day,Period只能設定為3;如果PeriodUnit設定為Month,Period可以設定為1-9,12。
  period = 1
  # 資料盤
  #data_disk {
    # 資料盤大小,單位:GB
    #size     = 20
    # 資料盤類型。可選值:cloud_efficiency(高效雲端硬碟)、cloud_ssd(SSD雲端硬碟)、local_hdd(本地HDD磁碟)、local_ssd(本地SSD磁碟)。
    #category = "cloud_efficiency"
  #}
  #  (可選, 自v1.208.0起可用) 是否分配公網IP標識符。值:true(預設):分配、false:不分配。
  public_ip_identification   = true  
  # 購買資源的時間單位。值:Month(預設):按月購買、Day:按天購買。
  period_unit                = "Month" 
  # 調度策略。可選值:Concentrate(節點級調度)、Disperse(地區調度)。
  scheduling_strategy        = "Disperse" 
  # 調度層級,通過它進行節點級調度或地區調度。可選值:Node-level scheduling(節點級調度):Region;Regional scheduling(地區調度):Big(地區)、Middle(省)、Small(市)。
  schedule_area_level        = "Big"  
  # 執行個體的鏡像ID。arm版本卡不能填寫。
  image_id                   = var.image_id
  # 執行個體規格。
  instance_type              = var.instance_type
  # 執行個體的主機名稱
  host_name                  = "Host80" 
  # 執行個體密碼
  password                   = "Ens-test@" 
  # 執行個體頻寬計費方式。如果首次購買時可以選擇計費方式,則後續該欄位的值將按照首次選擇的計費方式進行處理。可選值:BandwidthByDay(按日峰值頻寬)、95bandwidthbymonth(95峰值頻寬)。
  internet_charge_type       = var.internet_charge_type
  #  執行個體付款條件。自v1.230.0起可以修改payment_type。可選值:Subscription(預付費,訂用帳戶)、PayAsYouGo(隨用隨付)。
  payment_type              = "PayAsYouGo"
  # 電訊廠商,為地區調度所需。可選值:cmcc(移動)unicom(聯通)telecom(電信)
  carrier                   = "cmcc"
  # 調度價格策略。如果未填,將預設為低價優先。
  scheduling_price_strategy  = "PriceLowPriority"
  # 最大公網頻寬
  internet_max_bandwidth_out = 1
  # 節點ID。當ScheduleAreaLevel為Region時,EnsRegionId是必需的。當ScheduleAreaLevel為Big、Middle、Small時,EnsRegionId無效。
  # ens_region_id              = "cn-zhengzhou-telecom"  
  # 添加 net_district_code 參數
  net_district_code             = "100102" # 請根據實際規範調整
  # 系統硬碟規格
  system_disk {
    size = 40
  }
}

如果您想體驗更多完整樣本,請前往更多完整樣本中對應產品的檔案夾查看。

  • 本頁導讀 (1, M)
  • 前提條件
  • 使用的資源
  • 使用Terraform建立ENS執行個體
  • 操作步驟
  • 清理資源
  • 完整樣本
  • 範例程式碼
文檔反饋
phone 聯絡我們

立即和Alibaba Cloud在線服務人員進行交談,獲取您想了解的產品信息以及最新折扣。

alicare alicarealicarealicare