背景 当您在Virtual-Node节点部署一个bare pod应用,在程序迭代过程解决一些bug或者增加一些特性后,制作新镜像,需要更新bare pod镜像,同时需要保证Pod的IP不变。您可以参考此文档。
前提条件 您需要开通弹性容器实例 ECI 服务、访问控制 (RAM) 服务。并完成对弹性容器实例 ECI 服务的 RAM 角色授权。 在本地安装kubectl命令,同时保证kubectl可以与您的kubernetes集群交互。可以参考通过 kubectl 连接 Kubernetes 集群。 通过命令创建Pod 准备一个简单的Pod:
apiVersion: v1 kind: Pod metadata: name: nginx namespace: default spec: nodeName: virtual-kubelet containers: - image: nginx:1.7.9 imagePullPolicy: Always name: nginx 执行命令创建Pod:
kubectl create -f nginx.yaml 通过命令查询Pod信息 $ kubectl get pod/nginx -n default -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx 1/1 Running 0 7m34s 192.168.0.29 virtual-kubelet 通过ECI控制台查询Pod信息 eci_detail_1
通过命令修改Pod镜像 通过kubectl修改bare pod的镜像或者镜像tag可以采用一下几种方式:
kubectl patch kubectl edit kubectl apply 演示将Pod的镜像nginx:1.7.9修改为nginx:1.9.6
kubectl apply方式 修改容器镜像tag
apiVersion: v1 kind: Pod metadata: name: nginx namespace: default spec: nodeName: virtual-kubelet containers: - image: nginx:1.9.6 imagePullPolicy: Always name: nginx 执行kubectl apply:
kubectl apply -f nginx.yaml 执行kubectl验证镜像和IP:
$ kubectl get pod/nginx -n default -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx 1/1 Running 0 8m27s 192.168.0.29 virtual-kubelet kubectl edit方式 执行edit命令进入交互模式,修改Pod镜像:
kubectl edit pod/nginx -o yaml 执行kubectl验证镜像和IP:
$ kubectl get pod/nginx -n default -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx 1/1 Running 0 9m11s 192.168.0.29 virtual-kubelet kubectl patch方式 执行patch命令修改Pod内容器镜像:
kubectl patch pod nginx -p '{"spec":{"containers":[{"name": "nginx","image": "nginx:1.9.6"}]}}' 执行kubectl验证镜像和IP:
$ kubectl get pod -n default -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NODE READINESS GATES nginx 1/1 Running 0 9m43s 192.168.0.29 virtual-kubelet 通过ECI控制台验证 Pod执行完镜像更新操作后,可以去ECI控制台查看ContainerGroup详情,确认镜像是否修改成功。
eci_detail_2
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。