Python2.7.12の環境で、concurrent.futures.ProcessPoolExecutor を使い
並列処理を実装しています。
(訳あって、multiprocessing の並列処理関数は使っていません。Queue関数は使用。)
Python
1class A(): 2 def __init__(self): 3 self.queue = multiprocessing.Queue(maxsize=1024) 4 5 6 def proc(): 7 todo = [] 8 proc_list = get_classes() # 処理をさせたいクラス群を取得 9 with concurrent.futures.ProcessPoolExecutor() as executor: 10 for p in proc_list: 11 future = executor.submit(p.func, self.queue) # ★ 12 todo.append(future) 13 14 for future in futures.as_completed(todo): 15 res = future.result()
上記のコードを実行すると★部分で以下のエラーが発生します。
Traceback (most recent call last):
File "/usr/lib/python2.7/multiprocessing/queues.py", line 268, in _feed
send(obj)
File "/usr/lib/python2.7/multiprocessing/queues.py", line 77, in getstate
assert_spawning(self)
File "/usr/lib/python2.7/multiprocessing/forking.py", line 52, in assert_spawning
' through inheritance' % type(self).name
RuntimeError: Queue objects should only be shared between processes through inheritance
ProcessPoolExecutorをThreadPoolExecutorに変更するとエラーなく正常処理します。
以下の条件で回避方法がありましたらご教授下さい。
(a)マルチコアでもGlobal Interpreter Lock機構の制限を受けるThreadPoolExecutorは使わない
(b)multiprocessingの並列処理も使わない
(c)ProcessPoolExecutorまたは上記(a)(b)以外の手法で並列化を実現したい
(d)multiprocessing.Queueは、並列化する関数(p.func)で参照したいのでできれば使いたいが
使わなくても同等の機能(キュー機構)が使えればそちらでも構わない
よろしくお願い致します。
以上です。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/05/30 12:40