python try 嵌套_python – 在多处理中启动嵌套进程

我有一个主文件启动多个进程,其中一个进程再次启动多个进程.我在启动嵌套的进程集时遇到问题.

我在一个文件中有以下代码:

# parallel_test.py

import Queue

import multiprocessing

import time

import threading

def worker(q):

while not q.empty():

try:

row = q.get(False)

print row

time.sleep(1)

except Queue.Empty:

break

def main():

print 'creating queue'

q = multiprocessing.Queue()

print 'enqueuing'

for i in range(100):

q.put(i)

num_processes = 15

pool = []

for i in range(num_processes):

print 'launching process {0}'.format(i)

p = multiprocessing.Process(target=worker, args=(q,))

p.start()

pool.append(p)

for p in pool:

p.join()

if __name__ == '__main__':

main()

单独运行此文件python parallel_test.py工作正常并按预期打印数字.但是从另一个文件作为另一个进程启动它会导致问题.我的主要档案:

# main_loop_test.py

import parallel_test

from multiprocessing import Pool

import time

def main():

targets = [parallel_test.main]

running = True

while running:

try:

p = Pool(12)

for target in targets:

p.apply_async(target)

p.close() # For some reason you need to run close() before join()

p.join() # What for all the steps to be done

print 'All steps done'

time.sleep(2)

except KeyboardInterrupt as e:

print "<<<<<<<<<<<<<<<<<>>>>>>>>>>>>>>>>>>"

running = False

if __name__ == '__main__':

main()

它parallel_test.py似乎试图启动一个进程(什么都不做)然后退出函数,main_loop_test.py打印’所有步骤完成’.没有打印过任何数字.输出:

creating queue

enqueuing

launching process 0

All steps done

creating queue

enqueuing

launching process 0

All steps done

出了什么问题?我在使用Pool时遇到了同样的问题,而不是在parallel_test.py中自己管理进程.但是,使用线程替换多处理可以正常工作.

解决方法:

当您从另一个程序将其作为子进程调用时,您无法从parallel_test创建子进程,因为该进程是作为守护进程创建的,并且如链接https://docs.python.org/2/library/multiprocessing.html中所述,不允许守护进程创建子进程处理.您必须通过将进程的守护进程属性设置为false来将进程创建为非守护进程,如下所示.

p = multiprocessing.Process(target=test.main)

p.daemon = False

p.start()

p.join()

在通过Pool模块创建子进程时,我不确定如何设置守护进程属性.您可以尝试通过初始化列表传递此属性.

标签:python,multiprocessing

来源: https://codeday.me/bug/20190728/1559765.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值