1.6. Red Hat OpenShift Pipelines 正式发行(GA)1.10 发行注记


在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10 包括在 OpenShift Container Platform 4.11、4.12 和 4.13 中。

1.6.1. 新功能

除了包括修复和稳定性改进的信息外,以下小节突出介绍了 Red Hat OpenShift Pipelines 1.10 中的新内容。

1.6.1.1. Pipelines

  • 在这个版本中,您可以在 PipelineRunTaskRun pod 模板中指定环境变量来覆盖或附加任务或步骤中配置的变量。另外,您可以在默认 pod 模板中指定环境变量,以对所有 PipelineRunsTaskRuns 全局使用这些变量。在这个版本中,添加了一个名为 forbidden-envs 的新默认配置来过滤环境变量,同时从 pod 模板传播。
  • 在这个版本中,管道中的自定义任务会被默认启用。

    注意

    要禁用此次更新,请在 feature-flags 配置自定义资源中将 enable-custom-tasks 标志设置为 false

  • 在这个版本中,支持 v1beta1.CustomRun API 版本进行自定义任务。
  • 在这个版本中,增加了对 PipelineRun reconciler 的支持,以创建自定义运行。例如,从 PipelineRuns 创建的自定义 TaskRuns 现在可以使用 v1beta1.CustomRun API 版本而不是 v1alpha1.Run,如果 custom-task-version 功能标记被设置为 v1beta1,而不是默认值 v1alpha1

    注意

    您需要更新自定义任务控制器,以侦听 *v1beta1.CustomRun API 版本,而不是 *v1alpha1.Run 以响应 v1beta1.CustomRun 请求。

  • 在这个版本中,在 v1beta1.TaskRunv1.TaskRun 规格中添加了一个新的 retries 字段。

1.6.1.2. 触发器

  • 在这个版本中,触发器支持创建 v1 API 版本的 Pipelines, Tasks, PipelineRuns, 和 TaskRuns 对象,以及 v1beta1 API 版本的 CustomRun 对象。
  • 在这个版本中,GitHub Interceptor 会阻止执行拉取请求触发器,除非由拥有者调用或所有者使用可配置的注释。

    注意

    要启用或禁用此更新,请在 GitHub Interceptor 配置文件中将 githubOwners 参数的值设置为 truefalse

  • 在这个版本中,GitHub Interceptor 能够添加以逗号分隔的、用于推送和拉取请求事件更改的所有文件的列表。更改的文件列表添加到顶层 extensions 字段中事件有效负载的 changed_files 属性中。
  • 在这个版本中,TLS 的 MinVersion 改为 tls.VersionTLS12,以便在启用了联邦信息处理标准 (FIPS) 模式时在 OpenShift Container Platform 上运行触发器。

1.6.1.3. CLI

  • 在这个版本中,增加了对在启动一个 Task, ClusterTaskPipeline 时传递一个 CSI(Container Storage Interface)文件作为工作区的功能。
  • 在这个版本中,为与任务、管道运行和任务运行资源关联的所有 CLI 命令添加了 v1 API 支持。Tekton CLI 适用于这些资源的 v1beta1v1 API。
  • 在这个版本中,增加了对 startdescribe 命令中的对象类型参数的支持。

1.6.1.4. Operator

  • 在这个版本中,在可选管道属性中添加了 default-forbidden-env 参数。参数包括禁止的环境变量,在通过 pod 模板提供时不应传播它们。
  • 在这个版本中,增加了对 Tekton Hub UI 中的自定义徽标的支持。要添加自定义徽标,请在 Tekton Hub CR 中将 customLogo 参数的值设置为 base64 编码 URI。
  • 在这个版本中,git-clone 任务的版本号增加到 0.9。

1.6.1.5. Tekton Chains

重要

Tekton 链只是一个技术预览功能。技术预览功能不受红帽产品服务等级协议(SLA)支持,且功能可能并不完整。红帽不推荐在生产环境中使用它们。这些技术预览功能可以使用户提早试用新的功能,并有机会在开发阶段提供反馈意见。

有关红帽技术预览功能支持范围的更多信息,请参阅技术预览功能支持范围

  • 在这个版本中,在测试时为 PipelineRunTaskRun 添加注解和标签。
  • 此更新添加了一个名为 slsa/v1 的新格式,它生成与以 in-toto 格式请求时生成的相同度。
  • 在这个版本中,Sigstore 功能从实验性功能中移出。
  • 在这个版本中,predicate.materials 函数包括来自 TaskRun 对象的所有步骤和 sidecar 的镜像 URI 和摘要信息。

1.6.1.6. Tekton Hub

重要

Tekton Hub 只是一个技术预览功能。技术预览功能不受红帽产品服务等级协议(SLA)支持,且功能可能并不完整。红帽不推荐在生产环境中使用它们。这些技术预览功能可以使用户提早试用新的功能,并有机会在开发阶段提供反馈意见。

有关红帽技术预览功能支持范围的更多信息,请参阅技术预览功能支持范围

  • 在这个版本中,支持在集群中安装、升级或降级 v1 API 版本的 Tekton 资源。
  • 在这个版本中,支持添加自定义徽标来代替 UI 中的 Tekton Hub 徽标。
  • 在这个版本中,对 tkn hub install 命令进行了扩展,增加了一个 --type artifact 标记,它会从 Artifact Hub 获取资源并将其安装到集群中。
  • 在这个版本中,增加了将 tier, catalog, 和 org 的信息作为标签添加到从 Artifact Hub 安装到您的集群中的资源的支持。

1.6.1.7. Pipelines 作为代码(Pipelines as Code)

  • 这个版本增强了传入的 Webhook 支持。对于在 OpenShift Container Platform 集群上安装的 GitHub 应用程序,您不需要为传入的 webhook 提供 git_provider 规格。相反,Pipelines as Code 会检测 secret,并将其用于传入的 Webhook。
  • 在这个版本中,您可以使用同一令牌从带有非默认分支的 GitHub 上的同一主机获取远程任务。
  • 在这个版本中,Pipelines 作为代码支持 Tekton v1 模板。您可以使用 v1v1beta1 模板,Pipelines 作为 PR 生成的代码读取。PR 在集群上以 v1 的形式创建。
  • 在此次更新之前,当 OpenShift 命名空间中找不到运行时模板时,OpenShift 控制台 UI 将使用硬编码的管道运行模板作为回退模板。在这个版本中,pipelines-as-code 配置映射中提供了一个新的默认管道运行模板,名为 pipelines-as-code-template-default 供控制台使用。
  • 在这个版本中,Pipelines as Code 支持 Tekton Pipelines 0.44.0 最小状态。
  • 在这个版本中,Pipelines as Code 支持 Tekton v1 API,这意味着 Pipelines as Code 现在与 Tekton v0.44 及更新的版本兼容。
  • 在这个版本中,除了为 OpenShift 和 Tekton 仪表板为 k8s 配置控制台外,您还可以配置自定义控制台仪表板。
  • 在这个版本中,Pipelines as Code 会检测使用 tkn pac create repo 命令启动的 GitHub 应用程序的安装,如果全局安装,则不需要 GitHub Webhook。
  • 在此次更新之前,如果 PipelineRun 执行出现错误,而不是附加到 PipelineRun 的任务,Pipelines as Code 无法正确报告失败。在这个版本中,Pipelines as Code 会在无法创建 PipelineRun 时在 GitHub 检查中正确报告错误。
  • 在这个版本中,Pipelines as Code 包含一个 target_namespace 变量,它扩展至执行 PipelineRun 的当前运行命名空间。
  • 在这个版本中,Pipelines 作为代码可让您绕过 CLI bootstrap GitHub 应用程序中的 GitHub Enterprise 问题。
  • 在这个版本中,当找不到存储库 CR 时,Pipelines as Code 不会报告错误。
  • 在这个版本中,如果找到多个管道使用相同名称运行,Pipelines as Code 会报告一个错误。

1.6.2. 可能会造成问题的更改

  • 在这个版本中,tkn 命令的早期版本与 Red Hat OpenShift Pipelines 1.10 不兼容。
  • 在这个版本中,从 Tekton CLI 删除了对 ClusterCloudEvent 管道资源的支持。您不能使用 tkn pipelineresource create 命令创建管道资源。另外,任务、集群任务或管道的 start 命令中不再支持管道资源。
  • 在这个版本中,从 Tekton 链中删除 tekton 作为公认格式。

1.6.3. 弃用和删除的功能

  • 在 Red Hat OpenShift Pipelines 1.10 中,ClusterTask 命令现已弃用,计划在以后的发行版本中删除。此更新中还弃用了 tkn task create 命令。
  • 在 Red Hat OpenShift Pipelines 1.10 中,tkn task start 命令中使用的标记 -i-o 现已弃用,因为 v1 API 不支持管道资源。
  • 在 Red Hat OpenShift Pipelines 1.10 中,tkn pipeline start 命令一起使用的标志 -r 已被弃用,因为 v1 API 不支持管道资源。
  • Red Hat OpenShift Pipelines 1.10 更新将 openshiftDefaultEmbeddedStatus 参数设置为 both,带有 fullminimal 嵌入式状态。更改默认嵌入式状态的标记也已弃用,并将被删除。另外,管道默认嵌入式状态将在以后的版本中更改为 minimal

1.6.4. 已知问题

  • 这个版本包括以下向后兼容的更改:

    • 删除 PipelineResources 集群
    • 删除 PipelineResources 云事件
  • 如果在集群升级后管道指标功能无法正常工作,请运行以下命令作为临时解决方案:

    $ oc get tektoninstallersets.operator.tekton.dev | awk '/pipeline-main-static/ {print $1}' | xargs oc delete tektoninstallersets
  • 在这个版本中,IBM Power、IBM zSystems 和 IBM® LinuxONE 不支持使用外部数据库,如 Crunchy PostgreSQL。反之,使用默认的 Tekton Hub 数据库。

1.6.5. 修复的问题

  • 在此次更新之前,opc pac 命令会生成一个运行时错误,而不是显示任何帮助。在这个版本中修复了 opc pac 命令来显示帮助信息。
  • 在此次更新之前,运行 tkn pac create repo 命令创建仓库需要 Webhook 详情。在这个版本中,tkn-pac create repo 命令在安装 GitHub 应用程序时不会配置 Webhook。
  • 在此次更新之前,当 Tekton Pipelines 创建 PipelineRun 资源时遇到问题时,Pipelines as Code 不会报告管道运行创建错误。例如,管道运行中的不存在的任务不会显示任何状态。在这个版本中,Pipelines as Code 显示来自 Tekton Pipelines 的正确错误消息以及缺少的任务。
  • 在这个版本中,UI 页面在成功身份验证后重定向。现在,您会被重定向到您试图登录到 Tekton Hub 的同一页面。
  • 在这个版本中修复了带有标志 --all-namespaces--output=yamllist 命令,用于集群任务、单个任务和管道。
  • 在这个版本中,删除了 repo.spec.url URL 末尾的正斜杠,使其与来自 GitHub 的 URL 匹配。
  • 在此次更新之前,marshalJSON 函数不会编译对象列表。在这个版本中,marshalJSON 函数会对对象列表进行 marshals 处理。
  • 在这个版本中,Pipelines 作为代码可让您绕过 CLI bootstrap GitHub 应用程序中的 GitHub Enterprise 问题。
  • 在这个版本中,当您的存储库有超过 100 个用户时,GitHub collaborator 会检查。
  • 在这个版本中,任务或管道的 signverify 命令现在可以在没有 kubernetes 配置文件的情况下正常工作。
  • 在这个版本中,如果在命名空间中跳过修剪器,Tekton Operator 会清理保留的修剪器 cron 作业。
  • 在此次更新之前,API ConfigMap 对象不会更新为目录刷新间隔配置的值。在这个版本中修复了 Tekon Hub CR 中的 CATALOG_REFRESH_INTERVAL API。
  • 在这个版本中,在更改 EmbeddedStatus 功能标记时,PipelineStatus 的协调已被修复。在这个版本中重置以下参数:

    • status.runsstatus.taskruns 参数为 nil,带有 minimal EmbeddedStatus
    • status.childReferences 参数为 nil,带有 full EmbeddedStatus
  • 在这个版本中,添加了一个到 ResolutionRequest CRD 的转换配置。在这个版本中,可以正确地配置从 v1alpha1.ResolutionRequest 请求到 v1beta1.ResolutionRequest 请求的转换。
  • 在这个版本中会检查与一个管道任务关联的重复工作区。
  • 在这个版本中修复了在代码中启用解析器的默认值。
  • 在这个版本中,使用解析器修复了 TaskRefPipelineRef 名称转换的问题。

1.6.6. Red Hat OpenShift Pipelines 正式发行(GA)1.10.1 发行注记

在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10.1 包括在 OpenShift Container Platform 4.11、4.12 和 4.13 中。

1.6.6.1. 修复了 Pipelines as Code 的问题

  • 在此次更新之前,如果来自有效负载的源分支信息包含 refs/heads/,但用户配置的目标分支仅包含分支名称,main 在 CEL 表达式中,推送请求将失败。在这个版本中,Pipelines as Code 会传递推送请求,并在有效负载中基本分支或目标分支具有 refs/heads/ 时触发管道。
  • 在此次更新之前,当无法创建 PipelineRun 对象时,从 Tekton 控制器接收的错误不会被报告给用户。在这个版本中,Pipelines as Code 会向 GitHub 界面报告错误消息,以便用户可以对错误进行故障排除。Pipelines as Code 还会报告管道执行过程中发生的错误。
  • 在这个版本中,当因为基础架构问题而无法在 OpenShift Container Platform 集群中创建 secret 时,Pipelines as Code 不会将 secret 回滚到 GitHub 检查接口。
  • 在这个版本中,删除了从 Red Hat OpenShift Pipelines 不再使用的已弃用的 API。

1.6.7. Red Hat OpenShift Pipelines 正式发布 1.10.2 发行注记

在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10.2 包括在 OpenShift Container Platform 4.11、4.12 和 4.13 中。

1.6.7.1. 修复的问题

在此次更新之前,Tekton Operator 中的一个问题会阻止用户将 enable-api-fields 标志的值设置为 beta。在这个版本中解决了这个问题。现在,您可以在 TektonConfig CR 中将 enable-api-fields 标志的值设置为 beta

1.6.8. Red Hat OpenShift Pipelines 正式发布 1.10.3 发行注记

在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10.3 包括在 OpenShift Container Platform 4.11、4.12 和 4.13 中。

1.6.8.1. 修复的问题

在此次更新之前,Tekton Operator 不会公开任何自定义的性能配置字段。在这个版本中,作为集群管理员,您可以根据您的需要自定义 TektonConfig CR 中的以下性能配置字段:

  • disable-ha
  • bucket
  • kube-api-qps
  • kube-api-burst
  • threads-per-controller

1.6.9. Red Hat OpenShift Pipelines 正式发行 1.10.4 发行注记

在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10.4 包括在 OpenShift Container Platform 4.11、4.12 和 4.13 中。

1.6.9.1. 修复的问题

  • 在这个版本中解决了管道运行中的 PipelineRef 字段的捆绑包解析器转换问题。现在,转换功能会在转换后将 kind 字段的值设置为 Pipeline 。
  • 在此次更新之前,pipelinerun.timeouts 字段被重置为 timeout.pipeline 值,忽略 timeout.taskstimeout.finally 值。在这个版本中解决了这个问题,并为 PipelineRun 资源设置正确的默认超时值。
  • 在此次更新之前,控制器日志包含不必要的数据。在这个版本中解决了这个问题。

1.6.10. Red Hat OpenShift Pipelines 正式发布(GA)1.10.5 发行注记

在这个版本中,除了 4.11、4.12 和 4.13 外,Red Hat OpenShift Pipelines 正式发布 (GA) 1.10.5 包括在 OpenShift Container Platform 4.10 中。

重要

Red Hat OpenShift Pipelines 1.10.5 仅适用于 OpenShift Container Platform 4.10、4.11、4.12 和 4.13 上的 pipelines-1.10 频道。它不适用于任何 OpenShift Container Platform 版本的 latest 频道。

1.6.10.1. 修复的问题

  • 在此次更新之前,使用 octkn 命令无法列出或删除大型管道运行。在这个版本中,通过压缩导致这个问题的巨页注解解决了这个问题。请注意,如果管道运行在压缩后仍然太大,则还会出现同样的错误。
  • 在此次更新之前,只有 pipelineRun.spec.taskRunSpecs[].podTemplate 对象中指定的 pod 模板才会被视为管道运行。在这个版本中,pipelineRun.spec.podTemplate 对象中指定的 pod 模板也会被考虑,并与 pipelineRun.spec.taskRunSpecs[].podTemplate 对象中指定的模板合并。

1.6.11. Red Hat OpenShift Pipelines 正式发行 1.10.6 发行注记

在这个版本中,Red Hat OpenShift Pipelines 正式发行(GA) 1.10.6 包括在 OpenShift Container Platform 4.10、4.11、4.12 和 4.13 中。

这个版本包括 tkn 命令行工具的更新版本。您可以在以下位置下载此工具的更新版本:

如果您使用 RPM 在 Red Hat Enterprise Linux (RHEL)上安装了 tkn 命令行工具,请使用 yum update 命令安装更新的版本。

1.6.11.1. 已知问题

  • 如果您输入 tkn task starttkn clustertask start 命令,tkn 命令行工具会显示错误消息。作为临时解决方案,要使用命令行启动任务或集群任务,请使用 OpenShift Pipelines 1.11 或更高版本提供的 tkn 工具版本。

1.6.11.2. 修复的问题

  • 在这个版本中,S2I 集群任务使用正式发行(GA)容器镜像。
  • 在这个版本中,webhook 不支持 HTTP/2.0 协议。所有对 Red Hat OpenShift Pipelines 的 webhook 调用都必须使用 HTTP/1.1 协议。
Red Hat logoGithubRedditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

© 2024 Red Hat, Inc.