將現有的管線作業部署至批次端點
適用於:Azure CLI ml 延伸模組 v2 (目前)Python SDK azure-ai-ml v2 (目前)
批次終端點可讓您部署管線元件,提供一個在 Azure Machine Learning 中操作管線的便捷方法。 批次端點接受用於部署的管線元件。 不過,如果您已經有成功執行的管線作業,Azure Machine Learning 可以接受該作業作為批次端點的輸入,並自動為您建立管線元件。 在本文中,您將了解如何使用現有的管線作業作為批次部署的輸入。
您將了解:
- 執行並建立您想要部署的管線作業
- 從現有的作業建立批次部署
- 測試部署
關於此範例
在此範例中,我們將部署管線,其中包含列印 「hello world!」 的簡單命令作業。 我們指出要用於部署的現有管線作業,而不是在部署之前註冊管線元件。 Azure Machine Learning 接著會自動建立管線元件,並將其部署為批次端點管線元件部署。
本文中的範例是以 azureml-examples 存放庫中包含的程式碼範例為基礎。 若要在本機執行命令,而不需要複製或貼上 YAML 和其他檔案,請使用下列命令來複製存放庫,並移至您程式代碼撰寫語言的資料夾:
git clone https://github.com/Azure/azureml-examples --depth 1
cd azureml-examples/cli
此範例的檔案位於:
cd endpoints/batch/deploy-pipelines/hello-batch
必要條件
Azure 訂用帳戶。 如果您沒有 Azure 訂用帳戶,請在開始前建立免費帳戶。
Azure Machine Learning 工作區。 若要建立工作區,請參閱 管理 Azure Machine Learning 工作區。
Azure 機器學習 工作區中的下列許可權:
- 若要建立或管理批次端點和部署:請使用已指派
Microsoft.MachineLearningServices/workspaces/batchEndpoints/*
許可權的擁有者、參與者或自定義角色。 - 若要在工作區資源群組中建立 Azure Resource Manager 部署:請使用已指派
Microsoft.Resources/deployments/write
工作區部署之資源群組中許可權的擁有者、參與者或自定義角色。
- 若要建立或管理批次端點和部署:請使用已指派
Azure 機器學習 CLI 或適用於 Python 的 Azure 機器學習 SDK:
執行下列命令來安裝 Azure CLI 和
ml
Azure Machine Learning 的擴充功能:az extension add -n ml
批次端點的管線元件部署是在 Azure CLI 的
ml
延伸模組 2.7 版中引進。 使用az extension update --name ml
命令來取得最新版本。
連線到您的工作區
工作區是 Azure Machine Learning 的最上層資源。 它提供集中的位置,讓您在使用 Azure 機器學習 時,使用您建立的所有成品。 在本節中,您會連線到要執行部署工作的工作區。
在下列命令中,輸入您的訂用帳戶識別碼、工作區名稱、資源組名和位置:
az account set --subscription <subscription>
az configure --defaults workspace=<workspace> group=<resource-group> location=<location>
執行您想要部署的管線作業
在本節中,我們會從執行管線作業開始:
下列 pipeline-job.yml
檔案包含管線作業的設定:
pipeline-job.yml
$schema: https://azuremlschemas.azureedge.net/latest/pipelineJob.schema.json
type: pipeline
experiment_name: hello-pipeline-batch
display_name: hello-pipeline-batch-job
description: This job demonstrates how to run the a pipeline component in a pipeline job. You can use this example to test a component in an standalone job before deploying it in an endpoint.
compute: batch-cluster
component: hello-component/hello.yml
建立管線作業:
建立批次端點
在部署管線作業之前,我們需要部署批次端點來裝載部署。
提供端點的名稱。 批次端點的名稱在每個區域中都不得重複,因為該名稱會用於建構叫用 URI。 若要確保名稱不重複,請將任何尾端字元附加至下列程式碼中指定的名稱。
設定端點:
建立端點:
查詢端點 URI:
部署管線作業
若要部署管線元件,我們必須從目前的作業建立批次部署。
我們需要告訴 Azure Machine Learning 我們想要部署的作業名稱。 在我們的案例中,該作業會在下列變數中指出:
設定部署。
deployment-from-job.yml
檔案包含部署的設定。 請注意,我們如何使用密鑰job_definition
,而不是使用component
,來指出此部署是從管線作業建立的:deployment-from-job.yml
$schema: https://azuremlschemas.azureedge.net/latest/pipelineComponentBatchDeployment.schema.json name: hello-batch-from-job endpoint_name: hello-pipeline-batch type: pipeline job_definition: azureml:job_name_placeholder settings: continue_on_step_failure: false default_compute: batch-cluster
提示
此設定假設您具有名爲
batch-cluster
的計算叢集。 您可以將此值取代為您叢集的名稱。建立部署:
您的部署已可供使用。
測試部署
建立部署後,即可接收作業。 您可以叫用預設部署,如下所示:
您可以使用以下方式來監視顯示進度及串流記錄:
清除資源
完成後,請從工作區中刪除相關聯的資源:
執行下列程式碼,以刪除批次端點及其基礎部署。 --yes
用來確認刪除。
az ml batch-endpoint delete -n $ENDPOINT_NAME --yes