Nota
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
注意
本文档中详细介绍的 YAML 语法基于最新版本的 ML CLI v2 扩展的 JSON 架构。 此语法必定仅适用于最新版本的 ML CLI v2 扩展。 可以在 https://azuremlschemasprod.azureedge.net/ 上查找早期扩展版本的架构。
YAML 语法
| 密钥 | 类型 | 说明 | 允许的值 | 默认值 | 
|---|---|---|---|---|
| $schema | 字符串 | YAML 架构。 如果使用 Azure 机器学习 VS Code 扩展来创作 YAML 文件,则可通过在文件顶部包含 $schema来调用架构和资源完成操作。 | ||
| type | const | 必需。 组件的类型。 | spark | |
| name | 字符串 | 必需。 组件的名称。 必须以小写字母开头。 允许的字符是小写字母、数字和下划线 (_)。 最大长度为 255 个字符。 | ||
| version | 字符串 | 组件的版本。 如果省略,Azure 机器学习将自动生成一个版本。 | ||
| display_name | 字符串 | 组件在工作室 UI 中的显示名称。 在工作区中可以不唯一。 | ||
| description | 字符串 | 组件的说明。 | ||
| tags | object | 组件的标记字典。 | ||
| code | 字符串 | 必需。 包含此组件的源代码和脚本的文件夹的位置。 | ||
| entry | 对象 | 必需。 组件的入口点。 它可以定义 file。 | ||
| entry.file | string | 包含此组件的源代码和脚本的文件夹的位置。 | ||
| py_files | object | 要放置在 PYTHONPATH中的.zip、.egg或.py文件的列表,以便通过此组件成功执行作业。 | ||
| jars | 对象 | 要包含在 Spark 驱动程序和执行程序 CLASSPATH上的.jar文件列表,以便通过此组件成功执行作业。 | ||
| files | 对象 | 应复制到每个执行程序的工作目录的文件列表,以便通过此组件成功执行作业。 | ||
| archives | 对象 | 定义应提取到每个执行程序的工作目录中的存档列表,以便通过此组件成功执行作业。 | ||
| conf | 对象 | Spark 驱动程序和执行程序属性。 请参阅 conf键的属性 | ||
| environment | 字符串或对象 | 用于组件的环境。 此值可以是对工作区中现有版本受控环境的引用,也可以是对内联环境规范的引用。 若要引用现有环境,请使用 azureml:<environment_name>:<environment_version>语法或azureml:<environment_name>@latest(引用环境的最新版本)。若要以内联方式定义环境,请遵循环境架构。 排除 name和version属性,因为内联环境不支持这两个属性。 | ||
| args | string | 应传递到组件入口点 Python 脚本的命令行参数。 这些参数可能包含输入数据的路径以及写入输出的位置,例如 "--input_data ${{inputs.<input_name>}} --output_path ${{outputs.<output_name>}}" | ||
| inputs | object | 组件输入的字典。 键是组件上下文中的输入名称,值是输入值。 可以在 args中使用${{ inputs.<input_name> }}表达式引用输入。 | ||
| inputs.<input_name> | 数字、整数、布尔值、字符串或对象 | 文字值(数字、整数、布尔值或字符串类型)或包含组件输入数据规范的对象之一。 | ||
| outputs | object | 组件的输出配置字典。 键是组件上下文中的输出名称,值是输出配置。 可以在 args中使用${{ outputs.<output_name> }}表达式引用输出。 | ||
| outputs.<output_name> | object | Spark 组件输出。 通过提供包含组件输出规范的对象,可以将 Spark 组件的输出写入到某个文件或文件夹位置。 | 
conf 键的属性
| 键 | 类型 | 说明 | 默认值 | 
|---|---|---|---|
| spark.driver.cores | 整型 | Spark 驱动程序的核心数。 | |
| spark.driver.memory | 字符串 | 为 Spark 驱动程序分配的内存,以千兆字节 (GB) 为单位,例如 2g。 | |
| spark.executor.cores | integer | Spark 执行程序的核心数。 | |
| spark.executor.memory | 字符串 | 为 Spark Executor 分配的内存,以千兆字节 (GB) 为单位,例如 2g。 | |
| spark.dynamicAllocation.enabled | boolean | 是否应动态分配执行程序,作为 True或False值。 如果此属性设置为True,则定义spark.dynamicAllocation.minExecutors和spark.dynamicAllocation.maxExecutors。 如果此属性设置为False,则定义spark.executor.instances。 | False | 
| spark.dynamicAllocation.minExecutors | integer | 用于动态分配的 Spark 执行程序实例的最小数目。 | |
| spark.dynamicAllocation.maxExecutors | integer | 用于动态分配的 Spark 执行程序实例的最大数目。 | |
| spark.executor.instances | integer | Spark 执行程序实例的数目。 | 
组件输入
| 密钥 | 类型 | 说明 | 允许的值 | 默认值 | 
|---|---|---|---|---|
| type | 字符串 | 组件输入的类型。 为指向单个文件源的输入数据指定 uri_file,或为指向文件夹源的输入数据指定uri_folder。 详细了解数据访问。 | uri_file,uri_folder | |
| mode | 字符串 | 将数据传送到计算目标的模式。 direct模式会将存储位置的 URL 作为组件输入传入。 你完全负责处理存储访问凭据。 | direct | 
组件输出
| 密钥 | 类型 | 说明 | 允许的值 | 默认值 | 
|---|---|---|---|---|
| type | 字符串 | 组件输出的类型。 | uri_file,uri_folder | |
| mode | string | 将输出文件传送到目标存储资源的模式。 | direct | 
备注
az ml component 命令可用于管理 Azure 机器学习 Spark 组件。
示例
示例 GitHub 存储库中提供了示例。 下面显示了几个示例。
YAML:Spark 组件示例
# spark-job-component.yaml
$schema: https://azuremlschemas.azureedge.net/latest/sparkComponent.schema.json
name: titanic_spark_component
type: spark
version: 1
display_name: Titanic-Spark-Component
description: Spark component for Titanic data
code: ./src
entry:
  file: titanic.py
inputs:
  titanic_data:
    type: uri_file
    mode: direct
outputs:
  wrangled_data:
    type: uri_folder
    mode: direct
args: >-
  --titanic_data ${{inputs.titanic_data}}
  --wrangled_data ${{outputs.wrangled_data}}
conf:
  spark.driver.cores: 1
  spark.driver.memory: 2g
  spark.executor.cores: 2
  spark.executor.memory: 2g
  spark.dynamicAllocation.enabled: True
  spark.dynamicAllocation.minExecutors: 1
  spark.dynamicAllocation.maxExecutors: 4
YAML:包含 Spark 组件的管道作业示例
# attached-spark-pipeline-user-identity.yaml
$schema: https://azuremlschemas.azureedge.net/latest/pipelineJob.schema.json
type: pipeline
display_name: Titanic-Spark-CLI-Pipeline-2
description: Spark component for Titanic data in Pipeline
jobs:
  spark_job:
    type: spark
    component: ./spark-job-component.yml
    inputs:
      titanic_data: 
        type: uri_file
        path: azureml://datastores/workspaceblobstore/paths/data/titanic.csv
        mode: direct
    outputs:
      wrangled_data:
        type: uri_folder
        path: azureml://datastores/workspaceblobstore/paths/data/wrangled/
        mode: direct
    identity:
      type: user_identity
    compute: <ATTACHED_SPARK_POOL_NAME>
