弃用 API 迁移指南

随着 Kubernetes API 的演进,API 会定期重组或升级。当 API 演进时,旧的 API 会被弃用并最终移除。本页包含从弃用 API 版本迁移到更新、更稳定 API 版本时需要了解的信息。

按发布版本列出的已移除 API

v1.32

v1.32 版本将停止提供以下已弃用的 API 版本

流量控制资源

FlowSchema 和 PriorityLevelConfiguration 的 flowcontrol.apiserver.k8s.io/v1beta3 API 版本在 v1.32 中将不再提供。

  • 请迁移 manifest 和 API 客户端以使用 flowcontrol.apiserver.k8s.io/v1 API 版本,该版本自 v1.29 起可用。
  • 所有现有持久化对象都可以通过新 API 访问
  • flowcontrol.apiserver.k8s.io/v1 中的显著变化
    • PriorityLevelConfiguration 的 spec.limited.nominalConcurrencyShares 字段仅在未指定时默认为 30,显式指定的值 0 不会被更改为 30。

v1.29

v1.29 版本停止提供以下已弃用的 API 版本

流量控制资源

FlowSchema 和 PriorityLevelConfiguration 的 flowcontrol.apiserver.k8s.io/v1beta2 API 版本自 v1.29 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.29 起可用的 flowcontrol.apiserver.k8s.io/v1 API 版本,或自 v1.26 起可用的 flowcontrol.apiserver.k8s.io/v1beta3 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • flowcontrol.apiserver.k8s.io/v1 中的显著变化
    • PriorityLevelConfiguration 的 spec.limited.assuredConcurrencyShares 字段已重命名为 spec.limited.nominalConcurrencyShares,并且仅在未指定时默认为 30,显式指定的值 0 不会被更改为 30。
  • flowcontrol.apiserver.k8s.io/v1beta3 中的显著变化
    • PriorityLevelConfiguration 的 spec.limited.assuredConcurrencyShares 字段已重命名为 spec.limited.nominalConcurrencyShares

v1.27

v1.27 版本停止提供以下已弃用的 API 版本

CSIStorageCapacity

CSIStorageCapacity 的 storage.k8s.io/v1beta1 API 版本自 v1.27 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.24 起可用的 storage.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

v1.26

v1.26 版本停止提供以下已弃用的 API 版本

流量控制资源

FlowSchema 和 PriorityLevelConfiguration 的 flowcontrol.apiserver.k8s.io/v1beta1 API 版本自 v1.26 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用 flowcontrol.apiserver.k8s.io/v1beta2 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

HorizontalPodAutoscaler

HorizontalPodAutoscaler 的 autoscaling/v2beta2 API 版本自 v1.26 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.23 起可用的 autoscaling/v2 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化

v1.25

v1.25 版本停止提供以下已弃用的 API 版本

CronJob

CronJob 的 batch/v1beta1 API 版本自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.21 起可用的 batch/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

EndpointSlice

EndpointSlice 的 discovery.k8s.io/v1beta1 API 版本自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.21 起可用的 discovery.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • discovery.k8s.io/v1 中的显著变化
    • 使用每个 Endpoint 的 nodeName 字段代替已弃用的 topology["kubernetes.io/hostname"] 字段
    • 使用每个 Endpoint 的 zone 字段代替已弃用的 topology["topology.kubernetes.io/zone"] 字段
    • topology 被替换为 deprecatedTopology 字段,该字段在 v1 中不可写

Event

Event 的 events.k8s.io/v1beta1 API 版本自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.19 起可用的 events.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • events.k8s.io/v1 中的显著变化
    • type 被限制为 NormalWarning
    • involvedObject 已重命名为 regarding
    • 创建新的 events.k8s.io/v1 Event 时,actionreasonreportingControllerreportingInstance 是必需的
    • 使用 eventTime 代替已弃用的 firstTimestamp 字段(该字段已重命名为 deprecatedFirstTimestamp,在新的 events.k8s.io/v1 Event 中不允许使用)
    • 使用 series.lastObservedTime 代替已弃用的 lastTimestamp 字段(该字段已重命名为 deprecatedLastTimestamp,在新的 events.k8s.io/v1 Event 中不允许使用)
    • 使用 series.count 代替已弃用的 count 字段(该字段已重命名为 deprecatedCount,在新的 events.k8s.io/v1 Event 中不允许使用)
    • 使用 reportingController 代替已弃用的 source.component 字段(该字段已重命名为 deprecatedSource.component,在新的 events.k8s.io/v1 Event 中不允许使用)
    • 使用 reportingInstance 代替已弃用的 source.host 字段(该字段已重命名为 deprecatedSource.host,在新的 events.k8s.io/v1 Event 中不允许使用)

HorizontalPodAutoscaler

HorizontalPodAutoscaler 的 autoscaling/v2beta1 API 版本自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.23 起可用的 autoscaling/v2 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化

PodDisruptionBudget

PodDisruptionBudget 的 policy/v1beta1 API 版本自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.21 起可用的 policy/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • policy/v1 中的显著变化
    • 写入 policy/v1 PodDisruptionBudget 的空 spec.selector{})将选择命名空间中的所有 Pod(在 policy/v1beta1 中,空的 spec.selector 不选择任何 Pod)。在任一 API 版本中,未设置 spec.selector 都不会选择任何 Pod。

PodSecurityPolicy

policy/v1beta1 API 版本的 PodSecurityPolicy 自 v1.25 起不再提供,并且 PodSecurityPolicy 准入控制器将被移除。

请迁移到 Pod 安全性准入第三方准入 webhook。有关迁移指南,请参见从 PodSecurityPolicy 迁移到内置的 PodSecurity 准入控制器。有关弃用的更多信息,请参见PodSecurityPolicy 弃用:过去、现在和未来

RuntimeClass

node.k8s.io/v1beta1 API 版本的 RuntimeClass 自 v1.25 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.20 起可用的 node.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

v1.22

v1.22 版本停止提供以下已弃用的 API 版本

Webhook 资源

MutatingWebhookConfiguration 和 ValidatingWebhookConfiguration 的 admissionregistration.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.16 起可用的 admissionregistration.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • v1 中 webhooks[*].failurePolicy 的默认值从 Ignore 更改为 Fail
    • v1 中 webhooks[*].matchPolicy 的默认值从 Exact 更改为 Equivalent
    • v1 中 webhooks[*].timeoutSeconds 的默认值从 30s 更改为 10s
    • v1 中移除了 webhooks[*].sideEffects 的默认值,并且该字段变为必需字段,只允许使用 NoneNoneOnDryRun
    • v1 中移除了 webhooks[*].admissionReviewVersions 的默认值,并且该字段变为必需字段(AdmissionReview 支持的版本为 v1v1beta1
    • 通过 admissionregistration.k8s.io/v1 创建的对象,列表中的 webhooks[*].name 必须是唯一的

CustomResourceDefinition

CustomResourceDefinition 的 apiextensions.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.16 起可用的 apiextensions.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • spec.scope 不再默认为 Namespaced,必须显式指定
    • v1 中移除了 spec.version;请改用 spec.versions
    • v1 中移除了 spec.validation;请改用 spec.versions[*].schema
    • v1 中移除了 spec.subresources;请改用 spec.versions[*].subresources
    • v1 中移除了 spec.additionalPrinterColumns;请改用 spec.versions[*].additionalPrinterColumns
    • v1 中 spec.conversion.webhookClientConfig 已移至 spec.conversion.webhook.clientConfig
    • v1 中 spec.conversion.conversionReviewVersions 已移至 spec.conversion.webhook.conversionReviewVersions
    • 创建 v1 CustomResourceDefinition 对象时,spec.versions[*].schema.openAPIV3Schema 现在是必需的,并且必须是结构化模式(structural schema)
    • 创建 v1 CustomResourceDefinition 对象时,不允许使用 spec.preserveUnknownFields: true;必须在模式定义中指定为 x-kubernetes-preserve-unknown-fields: true
    • additionalPrinterColumns 项中,v1 将 JSONPath 字段重命名为 jsonPath(修复了#66531

APIService

APIService 的 apiregistration.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.10 起可用的 apiregistration.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

TokenReview

TokenReview 的 authentication.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.6 起可用的 authentication.k8s.io/v1 API 版本。
  • 无显著变化

SubjectAccessReview 资源

LocalSubjectAccessReview, SelfSubjectAccessReview, SubjectAccessReview 和 SelfSubjectRulesReview 的 authorization.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.6 起可用的 authorization.k8s.io/v1 API 版本。
  • 显著变化
    • v1 中 spec.group 已重命名为 spec.groups(修复了#32709

CertificateSigningRequest

CertificateSigningRequest 的 certificates.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.19 起可用的 certificates.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • certificates.k8s.io/v1 中的显著变化
    • 对于请求证书的 API 客户端
      • spec.signerName 现在是必需的(参见已知 Kubernetes 签名者),并且不允许通过 certificates.k8s.io/v1 API 创建针对 kubernetes.io/legacy-unknown 的请求
      • spec.usages 现在是必需的,不能包含重复值,并且只能包含已知用途
    • 对于批准或签署证书的 API 客户端
      • status.conditions 不能包含重复的类型
      • status.conditions[*].status 现在是必需的
      • status.certificate 必须是 PEM 编码的,并且只能包含 CERTIFICATE

Lease

Lease 的 coordination.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.14 起可用的 coordination.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

Ingress

Ingress 的 extensions/v1beta1networking.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.19 起可用的 networking.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • spec.backend 已重命名为 spec.defaultBackend
    • 后端 serviceName 字段已重命名为 service.name
    • 数字类型的后端 servicePort 字段已重命名为 service.port.number
    • 字符串类型的后端 servicePort 字段已重命名为 service.port.name
    • 现在每个指定的路径都必须有 pathType。选项包括 PrefixExactImplementationSpecific。为了匹配未定义的 v1beta1 行为,请使用 ImplementationSpecific

IngressClass

IngressClass 的 networking.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.19 起可用的 networking.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

RBAC 资源

ClusterRole, ClusterRoleBinding, Role 和 RoleBinding 的 rbac.authorization.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.8 起可用的 rbac.authorization.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

PriorityClass

PriorityClass 的 scheduling.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.14 起可用的 scheduling.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

存储资源

CSIDriver, CSINode, StorageClass 和 VolumeAttachment 的 storage.k8s.io/v1beta1 API 版本自 v1.22 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用 storage.k8s.io/v1 API 版本
    • CSIDriver 自 v1.19 起在 storage.k8s.io/v1 中可用。
    • CSINode 自 v1.17 起在 storage.k8s.io/v1 中可用
    • StorageClass 自 v1.6 起在 storage.k8s.io/v1 中可用
    • VolumeAttachment 自 v1.13 起在 storage.k8s.io/v1 中可用
  • 所有现有持久化对象都可以通过新 API 访问
  • 无显著变化

v1.16

v1.16 版本停止提供以下已弃用的 API 版本

NetworkPolicy

NetworkPolicy 的 extensions/v1beta1 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.8 起可用的 networking.k8s.io/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问

DaemonSet

DaemonSet 的 extensions/v1beta1apps/v1beta2 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.9 起可用的 apps/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • spec.templateGeneration 已移除
    • 创建后 spec.selector 现在是必需且不可变的;请使用现有模板标签作为选择器以实现无缝升级
    • spec.updateStrategy.type 现在默认为 RollingUpdate(在 extensions/v1beta1 中默认是 OnDelete

Deployment

Deployment 的 extensions/v1beta1apps/v1beta1apps/v1beta2 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.9 起可用的 apps/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • spec.rollbackTo 已移除
    • 创建后 spec.selector 现在是必需且不可变的;请使用现有模板标签作为选择器以实现无缝升级
    • spec.progressDeadlineSeconds 现在默认为 600 秒(在 extensions/v1beta1 中没有默认期限)
    • spec.revisionHistoryLimit 现在默认为 10(在 apps/v1beta1 中默认是 2,在 extensions/v1beta1 中默认是保留所有)
    • maxSurgemaxUnavailable 现在默认为 25%(在 extensions/v1beta1 中默认是 1

StatefulSet

StatefulSet 的 apps/v1beta1apps/v1beta2 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.9 起可用的 apps/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • 创建后 spec.selector 现在是必需且不可变的;请使用现有模板标签作为选择器以实现无缝升级
    • spec.updateStrategy.type 现在默认为 RollingUpdate(在 apps/v1beta1 中默认是 OnDelete

ReplicaSet

ReplicaSet 的 extensions/v1beta1apps/v1beta1apps/v1beta2 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.9 起可用的 apps/v1 API 版本。
  • 所有现有持久化对象都可以通过新 API 访问
  • 显著变化
    • 创建后 spec.selector 现在是必需且不可变的;请使用现有模板标签作为选择器以实现无缝升级

PodSecurityPolicy

PodSecurityPolicy 的 extensions/v1beta1 API 版本自 v1.16 起不再提供。

  • 请迁移 manifest 和 API 客户端以使用自 v1.10 起可用的 policy/v1beta1 API 版本。
  • 请注意,policy/v1beta1 API 版本的 PodSecurityPolicy 将在 v1.25 中移除。

如何操作

测试禁用已弃用的 API

你可以通过启动禁用特定 API 版本的 API 服务器来测试集群,以模拟即将进行的移除。将以下标志添加到 API 服务器启动参数中:

--runtime-config=<group>/<version>=false

例如

--runtime-config=admissionregistration.k8s.io/v1beta1=false,apiextensions.k8s.io/v1beta1,...

定位已弃用 API 的使用位置

使用 1.19+ 版本中提供的客户端警告、指标和审计信息来定位已弃用 API 的使用位置。

迁移到未弃用的 API

  • 更新定制集成和控制器以调用未弃用的 API

  • 修改 YAML 文件以引用未弃用的 API

    你可以使用 kubectl convert 命令自动转换现有对象

    kubectl convert -f <file> --output-version <group>/<version>.

    例如,要将旧的 Deployment 转换为 apps/v1,你可以运行

    kubectl convert -f ./my-deployment.yaml --output-version apps/v1

    此转换可能会使用非理想的默认值。要了解有关特定资源的更多信息,请查阅 Kubernetes API 参考

最近修改:太平洋标准时间 2024 年 3 月 17 日上午 12:37:更新 v1.25 和 v1.26 版本的 HorizontalPodAutoscaler 弃用 API 迁移指南 (#45390) (f424d45142)