Docker从入门到精通——堆栈跟踪
堆栈跟踪
一、强制记录堆栈跟踪
-
Linux:
sudo kill -SIGUSR1 $(pidof dockerd)
-
视窗服务器:
获取 dockerd 的进程 ID
Get-Process dockerd
。运行带有标志的可执行文件
--pid=<PID of daemon>
。
这会强制记录堆栈跟踪,但不会停止守护进程。守护程序日志显示堆栈跟踪或包含堆栈跟踪的文件的路径(如果已记录到文件)。
守护程序在处理SIGUSR1
信号并将堆栈跟踪转储到日志后继续运行。堆栈跟踪可用于确定守护进程中所有 goroutine 和线程的状态。
二、查看堆栈跟踪
可以使用以下方法之一查看 Docker 守护进程日志:
- 通过
journalctl -u docker.service
在 Linux 系统上运行使用systemctl
/var/log/messages
,/var/log/daemon.log
, 或/var/log/docker.log
在较旧的 Linux 系统上
笔记
无法在 Docker Desktop for Mac 或 Docker Desktop for Windows 上手动生成堆栈跟踪。但是,如果遇到问题,您可以单击 Docker 任务栏图标并选择疑难解答以向 Docker 发送信息。
在 Docker 日志中查看如下消息:
...goroutine stacks written to /var/run/docker/goroutine-stacks-2017-06-02T193336z.log ...daemon datastructure dump written to /var/run/docker/daemon-data-2017-06-02T193336z.log
Docker 保存这些堆栈跟踪和转储的位置取决于您的操作系统和配置。您有时可以直接从堆栈跟踪和转储中获得有用的诊断信息。否则,您可以将此信息提供给 Docker 以帮助诊断问题。
分类:
Docker专题精讲
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具