Python: [Errno 32] Broken pipe异常分析
2015-07-29 21:56
796 查看
问题描述
一个比较简单的应用场景,在子进程中处理一些基本的业务逻辑,无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上。
相关文章推荐
- python处理网页时的unicode编码问题
- 《learning python the hard way》习题46 项目骨架搭建 问题小结(一)之软件包的安装
- python的除法
- Python多线程的threading Event
- fedora13 python2.6升级到python2.7
- Python笔记之不可不练
- python安装及入门
- openCV—Python(7)—— 彩色图像R、G、B分量的提取与合并及其相关颜色空间的转化
- Python 之 sklearn 交叉验证 数据拆分
- python获取指定路径下所有指定后缀文件的方法
- python学习——Numpy(1)
- Python 选择排序
- 3.Python基础 序列sequence
- Python re 正则模块
- python基础教程总结15——6 CGI远程编辑
- openCV—Python(6)—— 图像算数与逻辑运算
- python os.walk和os.path.walk
- 用python免登錄把人人網某個相冊的全部照片下載下來
- [python]学习笔记3-字符串内建函数2
- Python 用 os.walk 遍历目录