PipelineStep 類別
代表 Azure Machine Learning 管線中的執行步驟。
管線是由多個管線步驟所建構,這些步驟是管線中不同的計算單位。 每個步驟都可以獨立執行,並使用隔離的計算資源。 每個步驟通常都有自己的具名輸入、輸出和參數。
PipelineStep 類別是基類,其他專為常見案例所設計之內建步驟類別繼承的基類,例如 PythonScriptStep 、 DataTransferStep 和 HyperDriveStep 。
如需管線和 PipelineSteps 相關概觀,請參閱 什麼是 ML 管線。
- 繼承
-
builtins.objectPipelineStep
建構函式
PipelineStep(name, inputs, outputs, arguments=None, fix_port_name_collisions=False, resource_inputs=None)
參數
- fix_port_name_collisions
- bool
指定是否要修正名稱衝突。 如果 True 和輸入和輸出具有相同的名稱,則輸入前面會加上 「INPUT」。 預設值是 False。
備註
PipelineStep 是執行單位,通常需要執行目標 (計算目標) 、使用選擇性腳本引數和輸入執行的腳本,而且可以產生輸出。 此步驟也可以採取一些步驟特定的其他參數。
管線步驟可以一起設定為建構 Pipeline ,其代表可共用且可重複使用的 Azure Machine Learning 工作流程。 如果步驟內容 (腳本/相依性) ,以及輸入和參數保持不變,管線的每個步驟都可以設定為允許重複使用其先前的執行結果。 重複使用步驟時,不會提交要計算的作業,則會立即讓任何後續步驟使用上一次執行的結果。
Azure Machine Learning Pipelines 提供常見案例的內建步驟。 如需範例,請參閱 steps 封裝和 AutoMLStep 類別。 如需根據預先建置步驟建構管線的概觀,請參閱 https://aka.ms/pl-first-pipeline 。
衍生自 PipelineStep 的預先建置步驟是一個管線中使用的步驟。 如果您使用機器學習工作流程來建立可跨不同管線進行版本設定及使用的步驟,請使用 類別 Module 。
使用管線步驟、輸入/輸出資料和步驟重複使用時,請記住下列事項。
建議您針對個別步驟使用不同的source_directory位置。 如果管線步驟中的所有腳本都位於單一目錄中,則每次對一個腳本進行變更時,該目錄的雜湊都會變更,強制所有步驟重新執行。 如需針對不同步驟使用個別目錄的範例,請參閱 https://aka.ms/pl-get-started 。
針對每個步驟維護腳本和相依檔案的不同資料夾,有助於減少針對每個步驟建立的快照集大小,因為只會快照集特定資料夾。 由於步驟source_directory中的任何檔案變更都會觸發快照集的重新上傳,因此維護每個步驟的個別資料夾,有助於在管線中重複使用步驟,因為如果步驟的source_directory中沒有任何變更,則會重複使用步驟的上一次執行。
如果步驟中使用的資料位於資料存放區中,且allow_reuse為 True,則不會偵測到資料變更的變更。 如果資料上傳為步驟source_directory) 下快照集 (的一部分,但不建議這麼做,則雜湊將會變更,並觸發重新執行。
方法
create_input_output_bindings |
從步驟輸入和輸出建立輸入和輸出系結。 |
create_module_def |
建立描述步驟的模組定義物件。 |
create_node |
根據此步驟建立管線圖形的節點。 |
get_source_directory |
取得步驟的來原始目錄,並檢查腳本是否存在。 |
resolve_input_arguments |
比對引數的輸入和輸出,以產生引數字串。 |
run_after |
在指定的步驟之後執行此步驟。 |
validate_arguments |
驗證引數中所提供的步驟輸入和輸出是否位於輸入和輸出清單中。 |
create_input_output_bindings
從步驟輸入和輸出建立輸入和輸出系結。
create_input_output_bindings(inputs, outputs, default_datastore, resource_inputs=None)
參數
傳回
輸入系結和輸出系結的 Tuple。
傳回類型
create_module_def
建立描述步驟的模組定義物件。
create_module_def(execution_type, input_bindings, output_bindings, param_defs=None, create_sequencing_ports=True, allow_reuse=True, version=None, module_type=None, arguments=None, runconfig=None, cloud_settings=None)
參數
- module_type
- str
要建立之模組服務的模組類型。 目前僅支援兩種類型:'None' 和 'BatchInferencing'。 module_type
不同于 execution_type
,指定要用來執行此課程模組的後端服務種類。
- cloud_settings
- <xref:azureml.pipeline.core._restclients.aeva.models.CloudSettings>
將用於雲端的設定
傳回
模組定義物件。
傳回類型
create_node
根據此步驟建立管線圖形的節點。
abstract create_node(graph, default_datastore, context)
參數
- context
- <xref:azureml.pipeline.core._GraphContext>
圖形內容物件。
傳回
已建立的節點。
傳回類型
get_source_directory
取得步驟的來原始目錄,並檢查腳本是否存在。
get_source_directory(context, source_directory, script_name)
參數
- context
- <xref:azureml.pipeline.core._GraphContext>
圖形內容物件。
傳回
來原始目錄和雜湊路徑。
傳回類型
resolve_input_arguments
比對引數的輸入和輸出,以產生引數字串。
static resolve_input_arguments(arguments, inputs, outputs, params)
參數
傳回
傳回兩個專案的元組。 第一個是已解析引數的專案一般清單。 第二個是結構化引數的清單 (_InputArgument、_OutputArgument、_ParameterArgument和_StringArgument)
傳回類型
run_after
在指定的步驟之後執行此步驟。
run_after(step)
參數
備註
如果您想要執行步驟,例如步驟 1 和步驟 2 完成後的步驟 3,您可以使用:
step3.run_after(step1)
step3.run_after(step2)
validate_arguments
意見反應
提交並檢視相關的意見反應