云计算核心技术Docker教程:强制堆栈跟踪记录

如果守护程序无响应,则可以通过向SIGUSR1守护程序发送信号来强制记录完整的堆栈跟踪。
摘要

如果守护程序无响应,则可以通过向SIGUSR1守护程序发送信号来强制记录完整的堆栈跟踪。

Linux:

$ sudo kill -SIGUSR1 $(pidof dockerd)

Windows Server:

下载docker-signal。

获取dockerd的进程ID Get-Process dockerd。

运行带有标志的可执行文件--pid=。

这将强制记录堆栈跟踪,但不会停止守护程序。守护程序日志显示堆栈跟踪或包含堆栈跟踪的文件的路径(如果已将其记录到文件中)。

在处理SIGUSR1信号并将堆栈跟踪信息转储到日志之后,守护程序将继续运行。堆栈跟踪可用于确定守护程序中所有goroutine和线程的状态。

查看堆栈跟踪

可以使用以下方法之一查看Docker守护程序日志:

1.通过使用以下命令journalctl -u docker.service在Linux系统上运行systemctl

2./var/log/messages,/var/log/daemon.log或/var/log/docker.log在较旧的Linux系统上

无法在Mac的Docker桌面或Windows的Docker桌面上手动生成堆栈跟踪。但是,如果遇到问题,可以单击Docker任务栏图标,然后选择诊断和反馈以将信息发送给Docker。

Docker日志中查找如下消息:

...goroutine stacks written to /var/run/docker/goroutine-stacks-2021-06-02T193336z.log

...daemon datastructure dump written to /var/run/docker/daemon-data-2021-06-02T193336z.log

Docker保存这些堆栈跟踪和转储的位置取决于您的操作系统和配置。有时您可以直接从堆栈跟踪和转储中获得有用的诊断信息。否则,您可以将此信息提供给Docker,以帮助诊断问题。

中国IDC资讯网,是IDC产业最具权威性新闻报道中心,我们会在第一时间报道云计算、数据中心、大数据技术应用、云信息安全、IDC服务商,IDC机房,IDC行业分析、IDC主机托管等行情资讯。
Copyright © 2012-2021 IDC311.COM. IDC资讯网 版权所有        网站地图