遇到问题
在Ubuntu18
上使用nohup
执行脚本发现如果将输出定向到一个文件,无法输出内容。
但如果直接运行,终端输出正常。
python3 filename.py > runlog.out # no output
python3 filename.py # normal output
分析
检查文件输出定向,挂起运行后找到到对应的PID
,进入/proc/{PID}/fd
目录查看文件的输出定向:
发现正常。
在脚本输出后加入
sys.stdout.flush()
发现再挂起时输出到文件成功,找到问题。
解决办法
执行时加入-u
参数:
python3 -u filename.py > runlog.out
-u
参数可以强制使标准输出不经过缓冲区,直接输出到屏幕上。
或者可以在每次输出后在脚本内手动刷新缓冲区(如上文),也可以解决这个问题。