Docker 容器中的标准输出缓冲:Debian 与 Ubuntu 的案例
在 Docker 容器中执行代码时,标准输出缓冲可能会发生在在某些情况下,但在其他情况下则不然。在使用 io.MultiWriter 将 stdout 定向到控制台和日志文件的场景中会出现此问题。
根本原因:平台差异
根本原因造成此行为的原因在于基于 Debian 的映像和基于 Ubuntu 的映像之间的平台差异。 Debian 默认情况下会缓冲 stdout,而 Ubuntu 会同步处理 stdout。
使用 Dockerfile 进行演示
这可以使用两个 Dockerfile 进行说明,一个基于 Debian:wheezy 和Ubuntu 上的另一个:trusty:
# TRUSTY Dockerfile FROM ubuntu:trusty # ... (rest of the Dockerfile as provided in the problem description) # WHEEZY Dockerfile FROM debian:wheezy # ... (rest of the Dockerfile as provided in the problem description)
在基于 wheeze 图像的容器中运行 procwrap 会产生缓冲的标准输出,而在基于 trusty 图像的容器中运行它会产生同步的标准输出。但是,在没有 Docker 的 Debian VM 上运行 procwrap 不会出现 stdout 缓冲。
解决方案选项
要解决此问题,可以考虑以下几种方法:
最终,最佳方案取决于具体的应用和运行环境。
以上是为什么 Debian 和 Ubuntu Docker 容器之间的标准输出缓冲不同?的详细内容。更多信息请关注PHP中文网其他相关文章!