OSError:[WinError 87]参数不正确

时间:2018-02-05 17:06:26

标签: python

我正在python教程网站上学习分布式流程:https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/001431929340191970154d52b9d484b88a7b343708fcc60000#0

以下是作为主要流程运行的turorial代码。

task_master.py

import random, time, queue
from multiprocessing.managers import BaseManager


task_queue = queue.Queue()
result_queue = queue.Queue()

class QueueManager(BaseManager):
    pass

QueueManager.register('get_task_queue', callable=lambda:task_queue)
QueueManager.register('get_result_queue', callable=lambda:result_queue)
manager = QueueManager(address=('',5000), authkey=b'abc')
manager.start()
task = manager.get_task_queue()
result = manager.get_result_queue()
for i in range(10):
    n = random.randint(0,10000)
    print('Put task %d...' %n)
    task.put(n)
print('Try get result...')
for i in range(10):
    r = result.get(timeout = 10)
    print('Result:%s'%r)
manager.shutdown()
print('master exit.')

代码没有完成,因为它引发了一些错误,当我在计算机上运行它时,我不知道如何处理。

错误

D:\py>Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "C:\Users\Raven\AppData\Local\Programs\Python\Python36\lib\multiprocessing\spawn.py", line 99, in spawn_main
    new_handle = reduction.steal_handle(parent_pid, pipe_handle)
  File "C:\Users\Raven\AppData\Local\Programs\Python\Python36\lib\multiprocessing\reduction.py", line 82, in steal_handle
    _winapi.PROCESS_DUP_HANDLE, False, source_pid)
OSError: [WinError 87] The parameter is incorrect。

1 个答案:

答案 0 :(得分:1)

Windows中的多处理与linux不同 - 具体来说,windows使用spawn而linux使用fork(嗯,还有更多内容,但这是摘要)。< / p>

您正在关注的教程是根据提示在Linux上编写的,而您在Windows上。您可以告诉multiprocessing使用spawn代替fork这样的内容:

import random, time, queue
import multiprocessing
multiprocessing.set_start_method('spawn')

from multiprocessing.managers import BaseManager

这有帮助吗?