This page shows how to write and read a Container termination message.
Termination messages provide a way for containers to write information about fatal events to a location where it can be easily retrieved and surfaced by tools like dashboards and monitoring software. In most cases, information that you put in a termination message should also be written to the general Kubernetes logs.
You need to have a Kubernetes cluster, and the kubectl command-line tool must be configured to communicate with your cluster. If you do not already have a cluster, you can create one by using Minikube.
In this exercise, you create a Pod that runs one container. The configuration file specifies a command that runs when the container starts.
termination.yaml |
---|
|
Create a Pod based on the YAML configuration file:
export REPO=https://raw.githubusercontent.com/kubernetes/kubernetes.github.io/master
kubectl create -f $REPO/docs/tasks/debug-pod-container/termination.yaml
In the YAML file, in the cmd
and args
fields, you can see that the
container sleeps for 10 seconds and then writes “Sleep expired” to
the /dev/termination-log
file. After the container writes
the “Sleep expired” message, it terminates.
Display information about the Pod:
kubectl get pod termination-demo
Repeat the preceding command until the Pod is no longer running.
Display detailed information about the Pod:
kubectl get pod --output=yaml
The output includes the “Sleep expired” message:
apiVersion: v1
kind: Pod
...
lastState:
terminated:
containerID: ...
exitCode: 0
finishedAt: ...
message: |
Sleep expired
...
Use a Go template to filter the output so that it includes only the termination message:
kubectl get pod termination-demo -o go-template="{{range .status.containerStatuses}}{{.lastState.terminated.message}}{{end}}"
By default Kubernetes retrieves termination messages from
/dev/termination-log
. To change this to a different file,
specify a terminationMessagePath
field for your Container.
For example, suppose your Container writes termination messages to
/tmp/my-log
, and you want Kubernetes to retrieve those messages.
Set terminationMessagePath
as shown here:
apiVersion: v1
kind: Pod
metadata:
name: msg-path-demo
spec:
containers:
- name: msg-path-demo-container
image: debian
terminationMessagePath: "/tmp/my-log"
terminationMessagePath
field in
Container.