Python: [Errno 32] Broken pipe异常分析

问题描述

一个比较简单的应用场景,在子进程中处理一些基本的业务逻辑,无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上。

  • 8
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值