百木园-与人分享,
就是让自己快乐。

k8s pod log日志不显示python print打印的内容

问题

Python 程序代码中使用 print() 打印的内容,在查询 k8s pod 日志时不显示。

原因

Python 的 print() 函数签名如下:

print(*objects, sep=\' \', end=\'\\n\', file=None, flush=False)

摘录部分官方文档如下:

The file argument must be an object with a write(string) method; if it is not present or None, sys.stdout will be used. Since printed arguments are converted to text strings, print() cannot be used with binary mode file objects. For these, use file.write(...) instead.

由于没有显式地传递 file 参数,所以 Python 会默认使用 sys.stdout

sys.stdout

查阅官方文档,节选片段:

When interactive, the stdout stream is line-buffered. Otherwise, it is block-buffered like regular text files. The stderr stream is line-buffered in both cases. You can make both streams unbuffered by passing the -u command-line option or setting the PYTHONUNBUFFERED environment variable.

stdout是有缓存的,只有遇到换行或者积累到一定的大小,才会显示出来。

解决方案

解决方案在 envvar-PYTHONUNBUFFERED 中其实已经说明了,有两种:

  • 设置环境变量 PYTHONUNBUFFERED
  • 运行 python 程序时,使用 -u 命令选项

在 Dockerfile 中我们只需这样一行设置即可:

ENV PYTHONUNBUFFERED=1

参考

  • print(*objects, sep=\' \', end=\'\\n\', file=None, flush=False)
  • sys.stdout
  • envvar-PYTHONUNBUFFERED
  • Dockerfile env

image

文完撒花🎉!感谢观看👏!


来源:https://www.cnblogs.com/fengyinxu/p/python-print-no-show-in-k8s-pod-log.html
本站部分图文来源于网络,如有侵权请联系删除。

未经允许不得转载:百木园 » k8s pod log日志不显示python print打印的内容

相关推荐

  • 暂无文章