Supervisord 不显示通过 docker 查看的进程的标准输出

Supervisord does not show stdout from processes viewed via docker

尝试在 docker 中与主管一起捕获我的应用程序日志。

这是我的 supervisord.conf:

[supervisord]
logfile=/dev/null
nodaemon=true

[program:autofs]
command=automount -f
redirect_stderr=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0

[program:split-pdf]
command=bin/split-pdf-server
directory=/root/split-pdf
redirect_stderr=true
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0

启动容器后一切正常,我可以看到我的应用程序的结果运行(它在网络共享上创建 pdf 文件)

但是日志显示我的应用没有输出:

015-07-02 00:39:26,119 CRIT Supervisor running as root (no user in config file)
2015-07-02 00:39:26,124 INFO supervisord started with pid 5
2015-07-02 00:39:27,127 INFO spawned: 'split-pdf' with pid 8
2015-07-02 00:39:27,130 INFO spawned: 'autofs' with pid 9
2015-07-02 00:39:28,132 INFO success: split-pdf entered RUNNING state, process has stayed up for > than 1 seconds (startsecs)
2015-07-02 00:39:28,132 INFO success: autofs entered RUNNING state, process has stayed up for > than 1 seconds (startsecs)

这是我附加到 docker 容器时看到的唯一输出。

我在 ubuntu 15.04 docker 1.7.0

这不是 this question 的副本,因为我 运行 在一个容器中有多个进程。

事实证明一切正常,但有一些延迟。 当我尝试为其他一些产生更多日志消息的应用程序创建容器时,这些消息开始出现在日志文件中,但有延迟。

我测试的第一个应用程序在日志中每个任务只有 2 行,我想在它开始刷新到日志文件之前需要填充某种缓冲区。

这与管道缓冲有关。

我在 unbuffered mode 中通过 运行 python 解决了这个问题:

$ docker run -e PYTHONUNBUFFERED=1 imagename

有关此问题的讨论,请参阅 supervisor-stdout issue #10