在 Docker 容器里跑 Python 程序时,我们经常遇到通过print函数或者logging 模块输出的信息在容器 log 中迷之失踪,过了好久又迷之出现。这是因为 Python 在写 stdout 和 stderr 的时候有缓冲区,导致输出无法实时更新进容器 log。

有如下几种方法解决:

1.增加环境变量
对于使用print函数打印的内容,在运行容器时增加环境变量PYTHONUNBUFFERED=0就可以解决。

2.配置 logging 的 stream 参数

import logging
logging.basicConfig(stream=sys.stdout)

这样,通过 logging 模块打印的日志都会直接写到标准输出 stdout。

或者自定义两个StreamHandler分别配置为输出到 stdout 和 stderr,来对不同 log 分别进行输出处理。

3.WSGI server 配置参数
如果是以 WSGI server 运行的 web 应用,以 gunicorn 为例,在 gunicorn 的启动命令中增加参数--access-logfile - --error-logfile -即可。

Sailing Over the Caribbean From the International Space Station

Sailing Over the Caribbean From the International Space Station

placeHolder

「喝醉的酒鬼总能找到回家的路,喝醉的鸟儿则可能永远也回不了家了。」

这是数学家 George Pólya 在一百年前证明的定理。

翻译成可以简单理解的人类语言(并不是)则是:
在二维网络中随机游走是常返的,但在三维空间中则不是。

此处应有数据做支撑:
在二维网络中随机游走,回到出发点的概率是 100%;在三维空间中大约是 34%;而在八维空间中,这个概率只有 7.3%。

A drunk man will find his way home, but a drunk bird may get lost forever.

— MorningRocks