Skip to main content
简体中文版经机器翻译而成,仅供参考。如与英语版出现任何冲突,应以英语版为准。

了解 operator 升级工作流程

在使用 Trident 操作员升级 Trident 之前,您应该了解升级过程中发生的后台过程。这包括对 Trident 控制器、控制器 Pod 和节点 Pod 以及启用滚动更新的节点 DaemonSet 的更改。

Trident 操作员升级处理

安装和升级 Trident 的众多"使用 Trident 运算符的好处"之一是自动处理 Trident 和 Kubernetes 对象,而不会中断现有的已挂载卷。通过这种方式,Trident 可以支持零停机时间升级,或"滚动更新"。特别是,Trident 操作程序与 Kubernetes 集群进行通信以:

  • 删除并重新创建 Trident Controller 部署和节点 DaemonSet。

  • 将 Trident Controller Pod 和 Trident Node Pod 替换为新版本。

    • 如果节点未更新,则不会阻止更新剩余节点。

    • 只有运行 Trident Node Pod 的节点才能挂载卷。

提示 有关 Kubernetes 集群上的 Trident 架构的更多信息,请参见 "Trident 架构"

Operator 升级工作流

使用 Trident 操作员启动升级时:

  1. Trident 操作员

    1. 检测当前安装的 Trident 版本(version n)。

    2. 更新所有 Kubernetes 对象,包括 CRD、RBAC 和 Trident SVC。

    3. 删除版本 n 的 Trident Controller 部署。

    4. 为版本 n+1 创建 Trident Controller 部署。

  2. Kubernetesn+1 创建 Trident Controller Pod。

  3. Trident 操作员

    1. 删除 n 的 Trident 节点 DaemonSet。操作员不等待节点 Pod 终止。

    2. n+1 创建 Trident 节点守护进程集。

  4. Kubernetes 在不运行 Trident Node Pod n 的节点上创建 Trident Node Pod。这可确保一个节点上不会有多于一个任何版本的 Trident Node Pod。