赞
踩
静态Pod是由kubelet进行管理的仅存在于特定Node上的Pod。它们不能通过API Server进行管理,无法与ReplicationController、Deployment或者DaemonSet进行关联,并且kubelet无法对它们进行健康检查。静态Pod总是由kubelet创建的,并且总在kubelet所在的Node上运行。
通过在kubelet配置文件中设置staticPodPath,指定kebelet需要监控的配置文件所在的目录,kubelet会定期扫描该目录,并根据该目录下的.yaml或者.json文件进行创建操作
在目标节点下执行如下命令:
systemctl status kubelet
通过vim 打开目标文件,找到config文件所在路径
vim /usr/lib/systemd/system/kubelet.service.d/10-kubeadm.conf
通过vim打开目标文件,发现已经配置好了静态pod默认路径
vim /var/lib/kubelet/config.yaml
# 进入静态pod文件所在的目录
cd /etc/kubernetes/manifests
# 创建一个新的pod yaml文件
vim pod10.yaml
""" # pod10.yaml 内容如下:
apiVersion: v1
kind: Pod
metadata:
name: pod10
namespace: one-namespace
labels:
name: static-pod
spec:
containers:
- name: static-pod-1
image: nginx:latest
ports:
- name: web
containerPort: 80
"""
# 查看pod是否创建成功(master节点执行)(本人分别在两个节点上做了操作,所以会有两个查询结果)
kubectl get po -n one-namespace
"""
NAME READY STATUS RESTARTS AGE
pod10-16.0.0.101 1/1 Running 0 8m7s
pod10-16.0.0.102 1/1 Running 0 72s
"""
删除创建pod的目标文件即可。比如本例中
# 进入静态pod文件所在的目录
cd /etc/kubernetes/manifests
# 删除目标文件
rm -f pod10.yaml
# 稍后几秒,查看是否删除成功(可以看到,本来可以查到两个记录,现在仅剩下一条)
kubectl get po -n one-namespace
"""
NAME READY STATUS RESTARTS AGE
pod10-16.0.0.102 1/1 Running 0 7m18s
"""
1、kubelet直接管理的Pod为什么还能通过apiserver获取到?
因为kubelet会为每个它管理的静态pod,调用api-server创建一个对应的pod镜像。
由此以来,静态pod也能通过kubectl等方式进行访问,与其他控制器创建出来的pod看起来没有什么区别。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。