Python: [Errno 32] Broken pipe异常分析 - Go语言中文社区

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上。

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/u010096900/article/details/47134389
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-04-19 10:38:53
  • 阅读 ( 1211 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢