Docker守护进程日志在哪里?奇怪的是,无法通过man, StackOverflow或Docker Docs找到答案。注意,我不是要docker容器的STDOUT,而是通过daemon / proxy在客户端和容器之间进行故障排除通信的守护进程日志。


当前回答

我在Manjaro 20/Arch Linux下找不到日志。相反,我只是停止了docker守护进程,并在调试模式下用$ sudo dockerd -D重新启动守护进程来产生日志。不幸的是,官方Docker文档没有为Arch提供这个信息。 这不仅适用于Arch,一般情况下也适用于其他系统。

其他回答

增加了在windows中查找docker守护进程日志的方法:

try

当在Windows和Mac OSX上使用docker机器时,守护进程在虚拟机中运行。

首先,找到活动的Docker机器。

docker-machine ls 在输出的name列下找到活动docker机器的名称。

您可以将docker守护进程日志文件复制到本地目录进行分析:

Docker-machine SCP默认:/var/log/docker.log ./ 默认是激活docker机器的名称。

这取决于你的操作系统。下面是几个位置,其中包含针对少数操作系统的命令:

Ubuntu (old using upstart ) - /var/log/upstart/docker.log Ubuntu (new using systemd ) - sudo journalctl -fu docker.service Amazon Linux AMI - /var/log/docker Boot2Docker - /var/log/docker.log Debian GNU/Linux - /var/log/daemon.log CentOS - cat /var/log/message | grep docker CoreOS - journalctl -u docker.service Fedora - journalctl -u docker.service Red Hat Enterprise Linux Server - /var/log/messages | grep docker OpenSuSE - journalctl -u docker.service macOS - ~/Library/Containers/com.docker.docker/Data/log/vm/d‌​ocker.log Windows - Get-EventLog -LogName Application -Source Docker -After (Get-Date).AddMinutes(-5) | Sort-Object Time, as mentioned here.

你也可以通过这个命令查看日志:

docker service ps --no-trunc {serviceName}

如果您的操作系统使用systemd,那么您可以通过以下命令查看docker守护进程日志:

sudo journalctl -fu docker.service

Mac OSX的docker日志的位置已经更改为~/Library/Containers/com.docker.docker/Data/com.docker.driver.amd64-linux/console-ring

请参阅Docker Daemon文档