返回信息流我们组的一个用multiprocessing.dummy.pool写了个多线程程序,由于某些外部需求,这段时间我们把并行度设为了1.结果发现经常程序一个线程被不明原因阻塞后就把后面全堵住了的事。
求问下大家multiprocessing.dummy.pool有什么可以检测或对付这种被阻塞线程的方法吗
这是一条镜像帖。来源:北邮人论坛 / python / #24772同步于 2020/1/7
该镜像源已超过 30 天没有更新,可能在源站已被删除。
Python机器人发帖
python的multiprocessing.dummy.pool有什么对付被莫名阻塞的线
PMS
2020/1/7镜像同步6 回复
订阅后,新回复会通过你的通知中心匿名送达。
6 条回复
什么叫僵尸进程?因为自己的逻辑有问题死锁hang住了?
解死锁是一方面,另外如果为了保证高可用,可以定时发心跳包,或者往本地文件写时间戳,然后开另一个程序检查,如果超时就kill掉重启
【 在 Nroskill 的大作中提到: 】
: 什么叫僵尸进程?因为自己的逻辑有问题死锁hang住了?
: 解死锁是一方面,另外如果为了保证高可用,可以定时发心跳包,或者往本地文件写时间戳,然后开另一个程序检查,如果超时就kill掉重启
不像是死锁住了,像是程序莫名其妙地挂了,但是进程没死,结果堵在那了
首先你得明白僵尸进程产生的原因啊,之所以一个进程变成僵尸进程的原因是此进程在 terminate 之后其父进程没有调用 wait 系统调用检查其 terminate 的状态。
【 在 nitroethane 的大作中提到: 】
: 首先你得明白僵尸线程产生的原因啊,之所以一个进程变成僵尸线程的原因是此线程在 terminate 之后其父线程没有调用 wait 系统调用检查其 terminate 的状态。
我说的不准确,确切来说不是僵尸线程,是被不明原因莫名其妙阻塞的线程
加 print 调试吧,最常见的阻塞无非是 file i/o 和 network i/o 以及死锁的情况最多。或者项目不大的话 pdb 调试。
【 在 PMS 的大作中提到: 】
:我说的不准确,确切来说不是僵尸线程,是被不明原因莫名其妙阻塞的线程