У меня есть основной файл, запускающий несколько процессов, и один из процессов снова запускает несколько процессов. У меня возникают проблемы с запуском вложенного набора процессов.Запуск вложенных процессов при многопроцессорной обработке
У меня есть следующий код в одном файле:
# 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 "<<<<<<<<<<<<<<<<<<CAUGHT KEYBOARD INTERRUPT FROM USER>>>>>>>>>>>>>>>>>>>"
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
. Тем не менее, заменяет многопроцессорную обработку потоками.
В 'экземпляры Process' в' multiprocessing.Pool' всегда создаются с 'демон = true'; нет никакого способа контролировать это. – dano
Может ли он по-прежнему быть многопоточным с пулом. Трудный процесс в дочерних процессах? – Nickpick