CKAD-CN 考试知识点分享(16) 修改 container 名称

您必须连接到正确的主机。不这样做可能导致零分。
[candidate@base] $ ssh ckad00044


任务要求

在不删除现有资源的前提下,更新 rapid-goat 命名空间中的 Deployment busybox,具体操作如下:

  1. 将容器名称更改为 musl
  2. 将容器镜像更改为 busybox:musl
  3. 确保更新成功且 Deployment 正常运行。

⚠️ 注意不得删除或重建 Deployment,否则将导致零分。


步骤一:编辑 Deployment

使用 kubectl edit 命令直接修改 Deployment 配置:

bash 复制代码
kubectl -n rapid-goat edit deployment busybox

在打开的编辑器中进行以下修改:

1. 修改容器名称

将原容器 name 字段从 busybox 改为 musl

yaml 复制代码
name: musl
2. 更新容器镜像

image 字段从 busybox 改为 busybox:musl

yaml 复制代码
image: busybox:musl
3. (可选)更新 Pod 模板标签(建议)

为明确标识新版本,可更新 Pod 模板的标签(如 app: busybox-musl),但非必须:

yaml 复制代码
template:
  metadata:
    labels:
      app: busybox-musl
4. 确保 deployment 未暂停(关键)

如果配置中存在 paused: true,请删除或注释该行,否则 Deployment 不会应用更新:

yaml 复制代码
# paused: true  # 删除或注释此行

修改后的关键片段示例

yaml 复制代码
spec:
  template:
    spec:
      containers:
      - name: musl
        image: busybox:musl
        command:
        - sh
        - -c
        - while true; do echo 'Container is running...'; sleep 3000; done
        resources: {}

保存并退出编辑器。


步骤二:验证更新结果

1. 检查 Deployment 状态
bash 复制代码
kubectl -n rapid-goat rollout status deployment busybox

预期输出:

复制代码
deployment "busybox" successfully rolled out
2. 确认容器名称和镜像已更新
bash 复制代码
kubectl -n rapid-goat get deployment busybox -o jsonpath='{.spec.template.spec.containers[0].name}{"\t"}{.spec.template.spec.containers[0].image}{"\n"}'

输出应为:

复制代码
musl	busybox:musl
3. 查看 Pod 是否已更新
bash 复制代码
kubectl -n rapid-goat get pods

新 Pod 的镜像应为 busybox:musl,且容器名已生效。


总结

  • 使用 kubectl edit 可安全地现场更新 Deployment;
  • 修改 nameimage 字段以满足任务要求;
  • 确保 paused: true 被移除,否则更新不会触发;
  • 通过 rollout statusget pods 验证变更已成功应用。

更新完成后,Deployment 将滚动创建使用 busybox:musl 镜像且容器名为 musl 的新 Pod。

相关推荐
花酒锄作田8 分钟前
Debian 13基于kubeadm和containerd部署单节点kubernetes
kubernetes·containerd·cilium
Dontla7 小时前
Kubernetes流量管理双雄:Ingress与Gateway API解析(Nginx与Ingress与Gateway API的关系)
nginx·kubernetes·gateway
七夜zippoe7 小时前
Kubernetes与Python微服务编排实战:从基础部署到自动扩缩容
python·微服务·kubernetes·service·hpa
Hello.Reader8 小时前
Flink CLI 从提交作业到 Savepoint/Checkpoint、再到 YARN/K8S 与 PyFlink
大数据·flink·kubernetes
刘叨叨趣味运维1 天前
解剖K8s控制平面(上):API Server与etcd如何成为集群的“大脑“与“记忆“?
平面·kubernetes·etcd
-dcr1 天前
56.kubernetes弹性伸缩
云原生·容器·kubernetes
Hui Baby1 天前
K8S联邦负载
java·容器·kubernetes
qq_312920111 天前
K8s Ingress实战:七层负载均衡流量治理
容器·kubernetes·负载均衡
海鸥811 天前
k8s中Jenkins 配置文件「 更新不了 」
java·kubernetes·jenkins
Cyber4K1 天前
【Kubernetes专项】K8s 常见持久化存储方案及存储类动态 PV
云原生·容器·kubernetes