Docker 容器中的 stdout 缓冲
问题:
在 Docker 容器中运行进程可能会产生缓冲的 stdout 输出,这与在主机或 macOS 上执行进程时不同。使用 Go 1.6.3 时会观察到这种不一致的行为,并且在基于 Debian 镜像的容器中尤其明显。
分析:
问题在于 stdout 缓冲行为容器的。默认情况下,stdout 缓冲在 Docker 容器中,这意味着收集输出直到达到特定限制或触发刷新。这可能会导致在运行生成大量数据的进程时出现间歇性输出。
原因:
stdout 缓冲是 Docker 继承的 Linux 内核功能容器。它通过减少对主机文件系统的写入次数来优化系统性能。
解决方案:
有多种方法可以克服 Docker 容器中的 stdout 缓冲:
示例:
在提供的示例中,以下代码片段可用于禁用标准输出缓冲:
<code class="go">cmd := exec.Command("ping", "127.0.0.1") cmd.Stdout = io.MultiWriter(os.Stdout, logWriter) cmd.Env = append(os.Environ(), "unbuffer=true") err := cmd.Run()</code>
以上是为什么 Docker 容器中会出现标准输出缓冲?的详细内容。更多信息请关注PHP中文网其他相关文章!