共用方式為


Azure 部署環境的 Azure 開發人員 CLI 支援

Azure 開發人員 CLI (azd) 支援 Azure 部署環境。 Azure 部署環境 (ADE) 是預先設定的 Azure 資源集合,部署在預先定義的訂用帳戶中。 Azure 治理會根據環境類型套用至這些訂用帳戶,例如沙箱、測試、預備或生產環境。 使用 Azure 部署環境,您可以強制執行企業安全策略,並提供一組精心策劃的預先定義基礎結構即程式代碼 (IaC) 範本。

先決條件

請確認您已完成下列必要條件,才能使用 azd使用 Azure 部署環境:

啟用 Azure 部署環境支援

您可以使用標準命令,例如 azd upazd provision,設定 azd 來布建和部署資源至部署環境。 若要啟用 Azure 部署環境的支援,請執行下列命令:

azd config set platform.type devcenter

platform.type 設定為 devcenter時,所有 azd 遠端環境狀態和布建都會利用新的開發人員中心元件。 此設定也表示會有效地忽略本機範本中的 infra 資料夾。 相反地,azd 會使用開發人員中心目錄中定義的其中一個基礎結構範本來布建資源。

您也可以透過下列命令停用開發人員中心支援:

azd config unset platform

使用 Azure 部署環境

啟用開發人員中心功能時,某些常見 azd 命令的預設行為會變更以使用這些遠端環境。 開發人員中心功能會擴充標準 azd遠端環境支援所提供的功能。

azd init

開發人員中心模式中的 azd init 命令體驗會顯示所有 azd 相容的 ADE 範本,以供從您設定的類別目錄中選取。 在 init 程式中,在 azd 複製範本程式代碼之後,azure.yaml 檔案會自動更新,以根據所選範本包含 platform 區段與選取的組態。 組態包含開發人員中心名稱、目錄和環境定義。

azd init

azd up

azd up 命令會將您的應用程式封裝、布建及部署至 Azure 部署環境。 不過,azd up 命令的布建階段會使用遠端開發人員中心內策劃的基礎結構即程式代碼範本,而部署階段會在您的 azd 範本中部署原始程式碼。 啟用開發人員中心模式時,azd 會忽略本機 azd 範本中的 infra 資料夾,而且只會使用開發人員中心範本布建資源。 此命令也會提示您輸入任何必要值,例如 Azure 部署環境專案或環境類型。

azd up

azd template list

azd template list 命令會在開發人員中心目錄中顯示可用的基礎結構範本,而不是顯示預設 AZD Awesome 資源庫中的範本。 目錄 提供一組經過策劃和核准的基礎結構即程式代碼範本,您的開發小組可用來建立環境。

azd template list

顯示更新範本庫的螢幕快照。

azd provision

azd provision 命令會建立新的開發人員中心環境。 此命令會提示您輸入任何遺漏的值,例如環境類型或專案。 當命令執行時,它會使用相關聯的基礎結構範本,為該環境布建正確的 Azure 資源集合。 啟用開發人員中心模式時,azd 會忽略本機 azd 範本中的 infra 資料夾,而且只會使用開發人員中心範本布建資源。

azd provision

azd env list

azd env list 命令會顯示您在開發人員入口網站中看到的相同環境清單。

azd env list

標記 Azure 部署環境的資源

azure 部署環境的 azd 布建仰賴開發人員中心目錄中策劃的範本。 目錄中的範本不一定指派標籤給布建的 Azure 資源,讓您將應用程式服務與 azure.yaml 檔案中的關聯。 如果範本未指派標籤,您可以透過下列兩種方式之一解決此問題:

  • 請與您的開發人員中心目錄管理員合作,以確保布建的 Azure 資源包含標籤,使其與您 azure.yaml 檔案中定義的服務產生關聯。

  • azure.yaml 檔案中指定 resourceName,而不是使用標記:

    services:
        api:
            project: ./src/api
            host: containerapp
            language: js
            resourceName: sample-api-containerapp
        web:
            project: ./src/web
            host: containerapp
            language: js
            resourceName: sample-web-containerapp
    

設定開發人員中心設定

您可以在多個位置定義開發人員中心的 azd 設定。 這些位置會結合設定,以下列優先順序建立最終組態:

  1. 環境變數
  2. Azd 環境設定
  3. 項目組態
  4. 用戶設定

azd 會自動提示您輸入這些來源遺漏的任何組態值。 下列各節會詳細說明這些組態選項。

環境變數

azd將會探索及使用下列環境變數:

  • AZURE_DEVCENTER_NAME
  • AZURE_DEVCENTER_PROJECT
  • AZURE_DEVCENTER_CATALOG
  • AZURE_DEVCENTER_ENVIRONMENT_DEFINITION
  • AZURE_DEVCENTER_ENVIRONMENT_TYPE
  • AZURE_DEVCENTER_ENVIRONMENT_USER

定義組態

.azure/<env>/config.json 檔案中的 azd 環境範圍定義開發人員中心的組態:

{
    "platform": {
        "config": {
            "catalog": "SampleCatalog",
            "environmentDefinition": "Todo",
            "environmentType": "Dev",
            "name": "sample-devcenter",
            "Project": "SampleProject"
        }
    }
}

項目範圍

azure.yaml 檔案 platform 節點中,於 azd 項目範圍定義開發人員中心的組態:

name: todo-nodejs-mongo-aca
metadata:
    template: todo-nodejs-mongo-aca@0.0.1-beta
platform:
    type: devcenter
    config:
        catalog: SampleCatalog
        environmentDefinition: Todo
        name: sample-devcenter
        project: SampleProject
services:
    api:
        project: ./src/api
        host: containerapp
        language: js
    web:
        project: ./src/web
        host: containerapp
        language: js

用戶範圍

~/<user_profile>/.azd/config.json 檔案中的使用者範圍定義開發人員中心的組態:

{
    "platform": {
        "config": {
            "catalog": "SampleCatalog",
            "environmentDefinition": "Todo",
            "environmentType": "Dev",
            "name": "sample-devcenter",
            "Project": "SampleProject"
        }
    }
}