Kubernetes 静态Pod

静态Pod是由kubelet进行管理的仅存在特定的Node上的Pod。这些Pod不能通过API Server进行管理,也无法和RC、Deployment或者DaemonSet关联,并且不存在健康检查,该类型的Pod由kubelet创建的,并且只在kubelet所在的Node上运行。

创建静态Pod的方式有两种:

  • 配置文件
  • HTTP

一、配置文件

首先需要时设定kubelet启动参数“--podmainifest-path”,或者在kubelet的配置文件中设定staticPodPath,指定的路径是kubelet监控的路径(如果k8s集群由kubeadm搭建,那默认存储在目录/etc/kubernetes/manifests下),kubelet会定期检查该目录,并根据该目录下的yaml文件和json文件进行创建Pod操作。

例如:配置目录为/etc/kubelet.d,配置启动参数为--podmainifest-path=/etc/kubelet.d,然后重启kubelet。

在/etc/kubelet.d目录下放static_pod.yaml文件,内容如下:

---
apiVersion: v1
kind: Pod
metadata:
    name: static-pod
    labels:
        name: static-pod
spec:
    containers:
    - name: static-pod
      image: nginx
      ports:
      - name: web
        containerPort: 80

稍等片刻,便能够发现集群启动了一个pod(如长时间未启动,查看系统日志、var/log/messages)

$ kubectl get pods --all-namespaces
NAMESPACE     NAME                                           READY   STATUS    RESTARTS   AGE
default       static-pod-host-192-168-100-121                1/1     Running   0          8s

该pod无法使用API Server删除,如果尝试删除会使该pod处于pending状态,并且一直不会被删除。如果要删除该pod,只需要到之前存放yaml文件的目录下,删除相关的yaml文件即可

二、HTTP方式

同通过设定kubelet的启动参数‘--manifest-url’,kubelet将会定期从该URL地址下载Pod的定义文件,并以yanl或者json文件的格式进行解析,然后创建pod,实现方式和配置文件的方式一样

你可能感兴趣的:(Kubernetes,kubernetes,容器,云原生)