查看容器日志
The docker logs 命令显示正在运行的容器记录的信息。
The docker service logs 命令显示参与服务的所有容器记录的信息。
记录的信息和日志格式几乎完全取决于容器的端点命令。
默认情况下,docker logs 或 docker service logs 显示命令的输出,就像您在终端中以交互方式运行该命令时看到的一样。Unix
和 Linux 命令在运行时通常会打开三个 I/O 流,称为
STDIN、STDOUT 和 STDERR。STDIN 是命令的输入流,可能
包括来自键盘的输入或来自另一个命令的输入。STDOUT
通常是命令的正常输出,而 STDERR 通常用于输出
错误消息。默认情况下,docker logs 显示命令的 STDOUT 和
STDERR。要了解更多关于 I/O 和 Linux 的信息,请参阅
Linux 文档项目中关于 I/O 重定向的文章。
在某些情况下,docker logs 可能不会显示有用的信息,除非您采取
额外步骤。
- 如果您使用一个
日志驱动,它将日志发送到文件、
外部主机、数据库或其他日志后端,并且已禁用
“双重日志记录”,则
docker logs可能不会显示有用信息。 - 如果您的镜像运行的是非交互式进程(如 Web 服务器或数据库),该应用程序可能会将其输出发送到日志文件,而不是
STDOUT和STDERR。
在第一种情况下,您的日志以其他方式处理,您可以选择不使用 docker logs。在第二种情况下,官方 nginx 镜像展示了一种解决方法,而官方 Apache httpd 镜像展示了另一种。
官方 nginx 镜像创建了一个从 /var/log/nginx/access.log 到 /dev/stdout 的符号链接,并创建了另一个从 /var/log/nginx/error.log 到 /dev/stderr 的符号链接,覆盖了日志文件并导致日志被发送到相应的特殊设备。请参阅 Dockerfile。
官方 httpd 驱动程序更改 httpd 应用程序的配置,
将其正常输出直接写入 /proc/self/fd/1(即 STDOUT),
并将其错误输出写入 /proc/self/fd/2(即 STDERR)。请参阅
Dockerfile。
后续步骤
- 配置 日志驱动程序。
- 编写一个 Dockerfile。