Pod¶
Static Pods¶
- It is possible to create Pods by writing a file to a certain directory watched by Kubelet.
- These are called static pods. Unlike DaemonSet, static Pods cannot be managed with kubectl or other Kubernetes API clients.
- Static Pods do not depend on the apiserver, making them useful in cluster bootstrapping cases.
- The kubelet agent is responsible to watch each static Pod and restart it if it crashes.
- Also, static Pods may be deprecated in the future.
Note
The static Pods running on a node are visible on the API server but cannot be controlled by the API Server.
Edit an existing POD¶
Warning
Remember, you CANNOT edit specifications of an existing POD other than the below.
spec.containers[*].image
spec.initContainers[*].image
spec.activeDeadlineSeconds
spec.tolerations
Option A¶
- For the 1st option, run the
kubectl edit pod <pod name>
command. This will open the pod specification in an editor (vi editor
). Then edit the required properties. When you try to save it, you will be denied. This is because you are attempting to edit a field on the pod that is not editable.
A copy of the file with your changes is saved in a temporary location as shown above.
You can then delete the existing pod by running the command:
kubectl delete pod webapp
Then create a new pod with your changes using the temporary file
kubectl create -f /tmp/kubectl-edit-ccvrq.yaml
Option B¶
- The 2nd option is to extract the pod definition in YAML format to a file using the command
kubectl get pod webapp -o yaml > my-new-pod.yaml
vi my-new-pod.yaml
kubectl delete pod webapp
kubectl create -f my-new-pod.yaml
Multi-container pods¶
In a multi-container pod
, each container is expected to run a process that stays alive as long as the POD's lifecycle. For example in the multi-container pod that has a web application and logging agent, both the containers are expected to stay alive at all times. The process running in the log agent container
is expected to stay alive as long as the web application
is running. If any of them fails, the POD restarts.
But at times you may want to run a process that runs to completion in a container. For example a process that pulls a code or binary from a repository that will be used by the main web application. That is a task that will be run only one time when the pod is first created. Or a process that waits for an external service or database to be up before the actual application starts. That's where initContainers comes in.
Init Container¶
An initContainer is configured in a pod like all other containers, except that it is specified inside a initContainers section, like this:
apiVersion: v1
kind: Pod
metadata:
name: amar-app-pod
labels:
app: amar-app
spec:
containers:
- name: myapp-container
image: busybox:1.28
command: ['sh', '-c', 'echo The app is running! && sleep 3600']
initContainers:
- name: init-myservice
image: busybox
command: ['sh', '-c', 'git clone <some-repository-that-will-be-used-by-application> ; done;']
Init container must run to completion
When a POD is first created the initContainer
is run, and the process in the initContainer must run to a completion before the real container hosting the application starts.
Multiple init containers¶
You can configure multiple such initContainers as well, like how we did for multi-containers pod. In that case each init container is run one at a time in sequential order.
If any of the initContainers fail to complete, Kubernetes restarts the Pod repeatedly until the Init Container succeeds.
apiVersion: v1
kind: Pod
metadata:
name: amar-app-pod
labels:
app: amar-app
spec:
containers:
- name: myapp-container
image: busybox:1.28
command: ['sh', '-c', 'echo The app is running! && sleep 3600']
initContainers:
- name: init-myservice
image: busybox:1.28
command: ['sh', '-c', 'until nslookup myservice; do echo waiting for myservice; sleep 2; done;']
- name: init-mydb
image: busybox:1.28
command: ['sh', '-c', 'until nslookup mydb; do echo waiting for mydb; sleep 2; done;']