互联网爱好者创业的站长之家 – 南方站长网
您的位置:首页 >微商 >

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

时间:2021-03-23 18:50:56 | 来源:TechWeb

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

如果守护程序无响应,则可以通过向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-2017-06-02T193336z.log

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

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

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如有侵权行为,请第一时间联系我们修改或删除,多谢。

猜你喜欢