问题描述
一个比较简单的应用场景,在子进程中处理一些基本的业务逻辑,无socket相关的通信。
def subprocess():
......
def mainprocess():
pid = os.fork()
if pid == 0:
subprocess()
近期该业务模块不能正常工作,并报告[Errno 32] Broken pipe异常。
运行环境:Python 2.6, Ubuntu 9.04
问题分析
[Errno 32] Broken pipe异常属于IOError,因此此问题和IO操作有关。检查相关的业务逻辑:
1. 之前的处理,相关的日志均通过log模块记录到文件中,无此异常
2. 检查相关的源码的修改记录,发现近期有开发人员没有使用log模块记录日志,而采用了print直接操作,初步推测可能和这部分代码有关
根据上述分析,通过Eclipse+Pydev的环境进行调试,居然可以正常运行;但shell下启动响应的脚本却依然有异常。print语句将输出信息定向到标准输出上,是否是输出满了导致的。进一步查看shell的启动代码,使用类似"nohup test.py"的形式启动,没有进行重定向输出重定向。
问题解决方案
综合上面的考虑,给出解决方案:
1. 直接使用print打印信息不是一个好的开发习惯,应该将信息记录到日志文件中;这样本身可以消除此问题
2. 启动脚本时,重定向标准输出:nohup test.py > /dev/null &2 > 1,将错误输出重定向到标准输出上,同时将标准输出重定向到/dev/null上。
版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/u010096900/article/details/47134389
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。