对 DaemonSet 执行回滚

    你必须拥有一个 Kubernetes 的集群,同时你的 Kubernetes 集群必须带有 kubectl 命令行工具。 建议在至少有两个节点的集群上运行本教程,且这些节点不作为控制平面主机。 如果你还没有集群,你可以通过 Minikube 构建一个你自己的集群,或者你可以使用下面任意一个 Kubernetes 工具构建:

    Your Kubernetes server must be at or later than version 1.7. To check the version, enter .

    你应该已经了解如何。

    如果只想回滚到最后一个版本,可以跳过这一步。

    列出 DaemonSet 的所有版本:

    此命令返回 DaemonSet 版本列表:

    1. daemonsets "<daemonset-name>"
    2. REVISION CHANGE-CAUSE
    3. 1 ...
    4. 2 ...
    • 在创建时,DaemonSet 的变化原因从 kubernetes.io/change-cause 注解(annotation) 复制到其修订版本中。用户可以在 kubectl 命令中设置 --record=true, 将执行的命令记录在变化原因注解中。
    1. kubectl rollout history daemonset <daemonset-name> --revision=1

    该命令返回相应修订版本的详细信息:

    1. kubectl rollout undo daemonset <daemonset-name> --to-revision=<revision>

    如果成功,命令会返回:

    1. daemonset "<daemonset-name>" rolled back

    Note: 如果 --to-revision 参数未指定,将选中最近的版本。

    kubectl rollout undo daemonset 向服务器表明启动 DaemonSet 回滚。 真正的回滚是在集群的 控制面 异步完成的。

    执行以下命令,来监视 DaemonSet 回滚进度:

    回滚完成时,输出形如:

    1. daemonset "<daemonset-name>" successfully rolled out

    要查看每个修订版本中保存的内容,可以找到 DaemonSet 修订版本的原生资源:

      该命令返回 ControllerRevisions 列表:

      每个 中存储了相应 DaemonSet 版本的注解和模板。

      kubectl rollout undo 选择特定的 ControllerRevision,并用 ControllerRevision 中存储的模板代替 DaemonSet 的模板。 kubectl rollout undo 相当于通过其他命令(如 kubectl editkubectl apply) 将 DaemonSet 模板更新至先前的版本。

      Note: 注意 DaemonSet 修订版本只会正向变化。也就是说,回滚完成后,所回滚到的 ControllerRevision 版本号 (.revision 字段) 会增加。 例如,如果用户在系统中有版本 1 和版本 2,并从版本 2 回滚到版本 1, 带有 .revision: 1 的 将变为 .revision: 3

      • 参阅 。

      最后修改 May 12, 2021 at 6:00 PM PST: [zh]Resync tasks files[11] (e43de9ad1)