--- approvers: - janetkuo title: 对 DaemonSet 执行回滚 content_type: task weight: 20 min-kubernetes-server-version: 1.7 --- 本文展示了如何对 {{< glossary_tooltip term_id="daemonset" text="DaemonSet" >}} 执行回滚。 ## {{% heading "prerequisites" %}} {{< include "task-tutorial-prereqs.md" >}} {{< version-check >}} 你应该已经了解如何[为 DaemonSet 执行滚东更新](/zh/docs/tasks/manage-daemon/update-daemon-set/)。 ## 对 DaemonSet 执行回滚 ### 步骤 1:找到想要 DaemonSet 回滚到的历史修订版本(revision) 如果只想回滚到最后一个版本,可以跳过这一步。 列出 DaemonSet 的所有版本: ```shell kubectl rollout history daemonset ``` 此命令返回 DaemonSet 版本列表: ```shell daemonsets "" REVISION CHANGE-CAUSE 1 ... 2 ... ... ``` * 在创建时,DaemonSet 的变化原因从 `kubernetes.io/change-cause` 注解(annotation) 复制到其修订版本中。用户可以在 `kubectl` 命令中设置 `--record=true`, 将执行的命令记录在变化原因注解中。 执行以下命令,来查看指定版本的详细信息: ```shell kubectl rollout history daemonset --revision=1 ``` 该命令返回相应修订版本的详细信息: ```shell daemonsets "" with revision #1 Pod Template: Labels: foo=bar Containers: app: Image: ... Port: ... Environment: ... Mounts: ... Volumes: ... ``` ### 步骤 2:回滚到指定版本 ```shell # 在 --to-revision 中指定你从步骤 1 中获取的修订版本 kubectl rollout undo daemonset --to-revision= ``` 如果成功,命令会返回: ```shell daemonset "" rolled back ``` {{< note >}} 如果 `--to-revision` 参数未指定,将选中最近的版本。 {{< /note >}} ### 步骤 3:监视 DaemonSet 回滚进度 `kubectl rollout undo daemonset` 向服务器表明启动 DaemonSet 回滚。 真正的回滚是在集群的 {{< glossary_tooltip term_id="control-plane" text="控制面" >}} 异步完成的。 执行以下命令,来监视 DaemonSet 回滚进度: ```shell kubectl rollout status ds/ ``` 回滚完成时,输出形如: ``` daemonset "" successfully rolled out ``` ## 理解 DaemonSet 修订版本 在前面的 `kubectl rollout history` 步骤中,你获得了一个修订版本列表,每个修订版本都存储在名为 `ControllerRevision` 的资源中。 要查看每个修订版本中保存的内容,可以找到 DaemonSet 修订版本的原生资源: ```shell kubectl get controllerrevision -l = ``` 该命令返回 `ControllerRevisions` 列表: ``` NAME CONTROLLER REVISION AGE - DaemonSet/ 1 1h - DaemonSet/ 2 1h ``` 每个 `ControllerRevision` 中存储了相应 DaemonSet 版本的注解和模板。 `kubectl rollout undo` 选择特定的 `ControllerRevision`,并用 `ControllerRevision` 中存储的模板代替 DaemonSet 的模板。 `kubectl rollout undo` 相当于通过其他命令(如 `kubectl edit` 或 `kubectl apply`) 将 DaemonSet 模板更新至先前的版本。 {{< note >}} 注意 DaemonSet 修订版本只会正向变化。也就是说,回滚完成后,所回滚到的 `ControllerRevision` 版本号 (`.revision` 字段) 会增加。 例如,如果用户在系统中有版本 1 和版本 2,并从版本 2 回滚到版本 1, 带有 `.revision: 1` 的`ControllerRevision` 将变为 `.revision: 3`。 {{< /note >}} ## 故障排查 * 参阅 [DaemonSet 滚动升级故障排除](/zh/docs/tasks/manage-daemon/update-daemon-set/#troubleshooting)。