nohup执行python脚本时重定向输出到文件失败

遇到问题

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参数可以强制使标准输出不经过缓冲区,直接输出到屏幕上。
或者可以在每次输出后在脚本内手动刷新缓冲区(如上文),也可以解决这个问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值