python 文件重定向无效,求帮忙看看

2016-05-12 15:12:01 +08:00
 EchoUtopia
创建了个守护进程,然后将标准输出重定向到一个文件,
但是发现这个文件里面并没有什么东西,如果不重定向可以正常输出到终端,
我用 python 终端打开这个文件: open("file","a+",0)也是能写入内容的,
所以想让大家帮忙看看哪个地方有问题
代码地址: https://github.com/EchoUtopia/my-python-practices/blob/master/watch_sync.py
在相关代码 make_deamon 函数里
3425 次点击
所在节点    Python
5 条回复
mengzhuo
2016-05-12 23:46:57 +08:00
进程之间没有联系啊
你以为子进程会把输出都自动发到父进程里么……
EchoUtopia
2016-05-13 18:06:55 +08:00
@mengzhuo 子进程会继承父进程的文件描述符啊,所以标准输入输出都继承下来了,我试验的时候把 os.dup2()重定向那部分去掉, print 信息都会输出到终端
WKPlus
2016-05-13 21:13:52 +08:00
怀疑是 buffer 的原因。
stdout 是屏幕输出的时候,是 line buffer 的;重定向到文件的话,是 fully buffer 的。
stderr 重定向到文件的话,也不是 fully buffer 的,你可以试试 stderr 的输出能不能看到,或者 stdout 多写点内容估计就能看到了
EchoUtopia
2016-05-16 10:35:13 +08:00
@WKPlus 我开始也感觉是 buffer ,但是 python 的 open 第三个参数设为 0 就去掉 buffer 了,但是还是不行
WKPlus
2016-05-16 21:51:13 +08:00
@EchoUtopia 我觉得你可以做两个测试: 1. 试试看 stderr 的输出能不能打印到文件 2. stdout 多打印点内容看看

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/278183

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX