Static Pods are a special type of Pod in Kubernetes that are managed directly by the kubelet daemon on a specific node, without the API server observing them. This means that Static Pods are not subject to the same scheduling and eviction rules as regular Pods.
Static Pods are typically used for running system-level applications directly on the node, outside the purview of Kubernetes control. For example, kubeadm uses Static Pods to bring up Kubernetes control plane components like api-server, controller-manager, and scheduler on the Master Node.
Working with Static Pods in Kubernetes involves manually managing Pods on a node without the involvement of the Kubernetes control plane. Static Pods are not managed by the Kubernetes API server or controller manager, making them useful for scenarios where you need to run system-level services or specific applications on a node without going through the typical Kubernetes deployment process. Here’s a step-by-step tutorial for working with Static Pods:
Prerequisites:
- A running Kubernetes cluster.
- Access to a Kubernetes node where you want to create Static Pods.
kubectl
installed and configured to communicate with your cluster.
How to craete a Static Pods?
- Create a Pod manifest file for your Static Pod. This manifest file should be in YAML format and should follow the same structure as a regular Pod manifest file.
- Place the Pod manifest file in a directory on the node where you want to run the Static Pod.
- Edit the kubelet configuration file on the node and add the following line:
pod-manifest-path: /path/to/pod/manifest/directory
- Restart the kubelet service on the node.
Once you have completed these steps, the kubelet will start the Static Pod.
A Step by Step Tutorials to create a static pods?
- Locate the Static Pods Directory:On each Kubernetes node, there is a directory where Static Pods’ manifest files are expected to be placed. The default directory is
/etc/kubernetes/manifests
. You can change this directory if needed by modifying the--pod-manifest-path
flag in your Kubernetes kubelet configuration. - Create a Static Pod Manifest:Create a manifest file (YAML) that describes the Static Pod you want to run. Here’s an example of a simple Nginx Static Pod manifest (
nginx-static-pod.yaml
):
apiVersion: v1
kind: Pod
metadata:
name: nginx-static-pod
labels:
app: nginx
spec:
containers:
- name: nginx
image: nginx:latest
- Save this file in the
/etc/kubernetes/manifests
directory on the node where you want to run the Static Pod. - Monitor the Static Pod:Kubernetes kubelet running on the node monitors the
/etc/kubernetes/manifests
directory for changes. It will detect the new Static Pod manifest and start the associated container(s).You can check the status of the Static Pod by SSHing into the node and using standard container management tools likedocker ps
orcontainerd
. - View Static Pod Logs:To view the logs of a Static Pod, use standard container log commands. For example:
docker logs <container-id>
- Modify or Delete Static Pods:To modify or delete a Static Pod, edit or delete the corresponding manifest file in the
/etc/kubernetes/manifests
directory. Kubelet will detect changes and act accordingly. - Monitoring and Troubleshooting:You can monitor the status of Static Pods using
kubectl
by specifying the node name and Pod name:
In Kubernetes Worker
In Kubernetes Master
Commands to work with Static Pods
To delete a Static Pod, you can simply delete the Pod manifest file from the node where the Static Pod is running.
Static Pods can be managed using the following kubectl commands:
- kubectl get pods – Lists all Pods in the current namespace, including Static Pods.
- kubectl describe pod – Displays detailed information about a Pod, including Static Pods.
- kubectl logs pod – Displays the logs for a Pod, including Static Pods.
- kubectl exec pod – Executes a command in a Pod, including Static Pods.
Do we need to restart kubelet for static pod
No, you do not need to restart kubelet for static pods. Kubelet automatically watches and restarts static pods if they fail. Static pods are managed directly by kubelet on a specific node, without the API server observing them.
However, there are a few cases where you may need to restart kubelet for static pods:
- If you have made changes to the kubelet configuration, such as the pod manifest path or the container runtime.
- If kubelet is not responding or is in a crashed state.
- If you are troubleshooting a problem with a static pod and restarting the pod does not fix the problem.
To restart kubelet, you can use the following command:
sudo systemctl restart kubelet
I’m a DevOps/SRE/DevSecOps/Cloud Expert passionate about sharing knowledge and experiences. I am working at Cotocus. I blog tech insights at DevOps School, travel stories at Holiday Landmark, stock market tips at Stocks Mantra, health and fitness guidance at My Medic Plus, product reviews at I reviewed , and SEO strategies at Wizbrand.
Please find my social handles as below;
Rajesh Kumar Personal Website
Rajesh Kumar at YOUTUBE
Rajesh Kumar at INSTAGRAM
Rajesh Kumar at X
Rajesh Kumar at FACEBOOK
Rajesh Kumar at LINKEDIN
Rajesh Kumar at PINTEREST
Rajesh Kumar at QUORA
Rajesh Kumar at WIZBRAND