【k8s】terminationMessagePath
环境
- kubernetes 1.20.4
- Spring Boot 2.5.0-M3
目标
terminationMessagePath 表示容器的异常终止消息的路径,默认在 /dev/termination-log 下。
当容器退出时,可以通过容器的状态看到退出信息。
示例
Pod.yaml
apiVersion: v1
kind: Pod
metadata:
name: busybox
spec:
containers:
- name: busybox
image: busybox:stable
command: ["/bin/sh"]
args: ["-c", "sleep 10 && echo Sleep expired > /dev/termination-log"]
可以看到,在睡眠 10 秒后,将 Sleep expired
输出到了异常退出的文件中。
查看退出信息
Containers:
busybox:
Container ID: docker://c1b7011b548235b140f42e5b6558a0912cefe57199a0fd1589697ac0aa434d85
Image: busybox:stable
Image ID: docker-pullable://busybox@sha256:ce2360d5189a033012fbad1635e037be86f23b65cfd676b436d0931af390a2ac
Port: <none>
Host Port: <none>
Command:
/bin/sh
Args:
-c
sleep 10 && echo Sleep expired > /dev/termination-log
State: Waiting
Reason: CrashLoopBackOff
Last State: Terminated
Reason: Completed
Message: Sleep expired
Exit Code: 0
Started: Sat, 27 Mar 2021 16:32:28 +0800
Finished: Sat, 27 Mar 2021 16:32:38 +0800
Ready: False
Restart Count: 2
Environment: <none>
Mounts:
/var/run/secrets/kubernetes.io/serviceaccount from default-token-slbq5 (ro)
只查看异常信息
[root@master ~]# kubectl get pod busybox -o go-template="{{range .status.containerStatuses}}{{.lastState.terminated.message}}{{end}}"
Sleep expired
自定义异常信息文件
apiVersion: v1
kind: Pod
metadata:
name: busybox
spec:
containers:
- name: busybox
image: busybox:stable
command: ["/bin/sh"]
terminationMessagePath: /root/test.log
args: ["-c", "sleep 10 && echo Sleep expired > /root/test.log"]
总结
查看异常退出信息,以及自定义退出的信息和文件位置。
附录
分类:
Kubernetes
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!