向 Selector 添加自定义 Task 镜像
本指南说明如何为 UI Task 表单中的 image 参数配置 selector 选项,涵盖两种场景:
- 为 hub Tasks 添加镜像
- 为 你自己的 namespace Tasks 添加镜像。
目录
功能概述使用场景前提条件场景 A:为 Hub Task selector 添加镜像1. 从 Task 描述符中查找 label selector2. 在 kube-public 中创建 ConfigMap3. 应用并验证场景 B:为你自己的 Task selector 添加镜像1. 在 Task 上配置style.tekton.dev/descriptors2. 在 kube-public 中创建匹配的 ConfigMap3. 应用并验证维护提示功能概述
- 每个 selector 选项都来自一个
ConfigMap,其data.name作为标签,data.image作为值。 - Task 特定的标签(例如
catalog.tekton.dev/tool-image-python)使 UI 能将ConfigMaps与正确的Task参数匹配起来。 - UI 使用
Task注解中指定的 namespace(例如kube-public),并通过Task描述符中定义的 label selector 进行查询,然后使用查询结果渲染 selector。
使用场景
- 为
Taskselector 添加自定义 registry mirror 镜像。 - 在现有 selector 选项之外引入新的 runtime minor 版本。
- 为自定义
Task提供加固镜像选项。
前提条件
- 已安装 Tekton Pipelines。
- 你可以在
kube-public中创建ConfigMaps。 - 你可以在目标
Task上设置style.tekton.dev/descriptors(Hub Tasks已经提供;自定义Tasks需要你添加它)。
场景 A:为 Hub Task selector 添加镜像
当你要扩展一个 Hub Task 的 selector 时,请使用此路径。
1. 从 Task 描述符中查找 label selector
在 Task 上找到 style.tekton.dev/descriptors 注解,并查找 path 指向 image 参数的条目。
以 urn:alm:descriptor:expression:props.options:api 结尾的 descriptor 包含一个 labelSelector=... 查询;其中的 label key 必须存在于你的 ConfigMap 中。
在下面的示例中,你需要在 kube-public namespace 中创建一个带有 catalog.tekton.dev/tool-image-python 标签的 ConfigMap。
有关 style.tekton.dev/descriptors 的更多信息,请参见 How to Configure Dynamic Forms。
2. 在 kube-public 中创建 ConfigMap
使用该 label key 创建一个 ConfigMap。
Default Tasks 随附带有标记为
catalog.tekton.dev/source: system的ConfigMaps,用于表示平台提供的条目。请勿修改或删除这些条目,你的自定义ConfigMaps也不应包含此标签。
3. 应用并验证
打开 Task 表单;selector 现在应包含 Python 3.10,并将镜像设置为
registry.example.com/tekton/python:3.10。
场景 B:为你自己的 Task selector 添加镜像
当你可以控制 Task 定义,并且需要同时配置 descriptors 和 ConfigMaps 时,请使用此路径。
1. 在 Task 上配置 style.tekton.dev/descriptors
下面是一个 image selector 的 Task descriptor 示例:
Descriptor 条目及其含义:
有关 style.tekton.dev/descriptors 的更多信息,请参见 How to Configure Dynamic Forms。
2. 在 kube-public 中创建匹配的 ConfigMap
使用 descriptor 查询的相同 label key。对于自定义 Tasks,建议使用不会与默认 Task selector 冲突的 label key,以避免在 Hub Tasks 中意外显示。
Default Tasks 随附带有标记为
catalog.tekton.dev/source: system的ConfigMaps,用于表示平台提供的条目。请勿修改或删除这些条目,你的自定义ConfigMaps也不应包含此标签。
你也可以将 ConfigMap 放在你偏好的其他 namespace 中;你只需要确保 ConfigMap 的 namespace 与 Task 的 style.tekton.dev/descriptors 注解中指定的 namespace 相同。
例如,你可以按下面的示例设置 Task 注解,请将 <NAMESPACE> 替换为你的 namespace。
3. 应用并验证
打开你的 Task 表单;selector 应列出 Python 3.13 (Team Edition),并将镜像设置为
registry.example.com/internal/python:3.13。
维护提示
- 通过编辑并重新应用其
ConfigMap来更新自定义选项。 - 通过仅删除你自己的自定义
ConfigMap来移除某个选项;保留任何带有catalog.tekton.dev/source: system的ConfigMap不变。