属主与附属
属主关系不同于一些资源使用的标签和选择算符机制。 例如,有一个创建 对象的 Service, 该 Service 使用标签来让控制平面确定,哪些 EndpointSlice
对象属于该 Service。 除开标签,每个代表 Service 所管理的 EndpointSlice
都有一个属主引用。 属主引用避免 Kubernetes 的不同部分干扰到不受它们控制的对象。
附属对象有一个 metadata.ownerReferences
字段,用于引用其属主对象。 一个有效的属主引用,包含与附属对象同在一个命名空间下的对象名称和一个 UID。 Kubernetes 自动为一些对象的附属资源设置属主引用的值, 这些对象包含 ReplicaSet、DaemonSet、Deployment、Job、CronJob、ReplicationController 等。 你也可以通过改变这个字段的值,来手动配置这些关系。 然而,通常不需要这么做,你可以让 Kubernetes 自动管理附属关系。
说明:
根据设计,kubernetes 不允许跨名字空间指定属主。 名字空间范围的附属可以指定集群范围的或者名字空间范围的属主。 名字空间范围的属主必须和该附属处于相同的名字空间。 如果名字空间范围的属主和附属不在相同的名字空间,那么该属主引用就会被认为是缺失的, 并且当附属的所有属主引用都被确认不再存在之后,该附属就会被删除。
在 v1.20+ 版本,如果垃圾收集器检测到无效的跨名字空间的属主引用, 或者一个集群范围的附属指定了一个名字空间范围类型的属主, 那么它就会报告一个警告事件。该事件的原因是 OwnerRefInvalidNamespace
, involvedObject
属性中包含无效的附属。 你可以运行 kubectl get events -A --field-selector=reason=OwnerRefInvalidNamespace
来获取该类型的事件。
当你告诉 Kubernetes 删除一个资源,API 服务器允许管理控制器处理该资源的任何 。 Finalizer 防止意外删除你的集群所依赖的、用于正常运作的资源。 例如,如果你试图删除一个仍被 Pod 使用的 ,该资源不会被立即删除, 因为 PersistentVolume
有 kubernetes.io/pv-protection
Finalizer。 相反,它将进入 Terminating
状态,直到 Kubernetes 清除这个 Finalizer, 而这种情况只会发生在 PersistentVolume
不再被挂载到 Pod 上时。
- 了解关于。