静态 Pod 直接由特定节点上的kubelet进程来管理,不通过 master
节点上的apiserver。无法与我们常用的控制器Deployment或者DaemonSet进行关联,它由kubelet进程自己来监控,当pod崩溃时重启该pod,kubelete也无法对他们进行健康检查。静态
pod 始终绑定在某一个kubelet,并且始终运行在同一个节点上。 kubelet会自动为每一个静态 pod 在 Kubernetes 的
apiserver 上创建一个镜像 Pod(Mirror Pod),因此我们可以在 apiserver 中查询到该 pod,但是不能通过
apiserver 进行控制(例如不能删除)。 创建静态 Pod 有两种方式:配置文件和 HTTP 两种方式。这里采用配置文件的方式创建
创建静态pod有两种方式一种是文件方式一种是http方式,本次采用文件方式创建。
通过kubeadm的方式来安装的集群环境,对应的kubelet已经配置了我们的静态 Pod 文件的路径,那就是/etc/kubernetes/manifests,所以我们只需要在该目录下面创建一个标准的 Pod 的 JSON 或者 YAML 文件即可。(配置文件为/var/lib/kubelet/config.yaml staticPodPath:/etc/kubernetes/manifests)
在其中一个节点的静态pod目录中添加yaml文件
[root@k8s-node1 manifests]# cat staticpod.yaml
apiVersion: v1
kind: Pod
metadata:
labels:
run: nginx
name: static-pod
spec:
containers:
- image: nginx:1.14
name: nginx
在主节点查看当前pod
[root@k8s-master ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
nginx-75dbbf4545-989rs 1/1 Running 1 17h
nginx-75dbbf4545-9sbw4 1/1 Running 1 17h
nginx-75dbbf4545-qtxr7 1/1 Running 1 17h
static-pod-k8s-node1 1/1 Running 1 56s
删除pod
[root@k8s-master ~]# kubectl delete pod static-pod-k8s-node1
pod "static-pod-k8s-node1" deleted
查看pod
[root@k8s-master ~]# kubectl get pod
NAME READY STATUS RESTARTS AGE
nginx-75dbbf4545-989rs 1/1 Running 1 17h
nginx-75dbbf4545-9sbw4 1/1 Running 1 17h
nginx-75dbbf4545-qtxr7 1/1 Running 1 17h
static-pod-k8s-node1 1/1 Running 1 15s
无法删除,删除只能去pod当前所处的主机,移除静态pod路径下的对应yaml文件。