为什么Python多处理管道不安全?

时间:2012-09-18 18:55:39

标签: python multiprocessing pipe unsafe

当有多个发件人和收件人时,我不明白为什么Pipes被称为不安全。

如果是这种情况,如何使用Queues将以下代码转换为代码? Queues关闭后不会抛出EOFError,因此我的流程无法停止。我是否应该无休止地发送“Poison”信息告诉他们停止(这样,我确定我的所有进程都至少收到一个毒药)?

我想保持管道p1打开,直到我另有决定(这是我发送10条消息的时候)。


from multiprocessing import Pipe, Process
from random import randint, random
from time import sleep

def job(name, p_in, p_out):
    print(name + ' starting')
    nb_msg = 0
    try:
        while True:
            x = p_in.recv()
            print(name + ' receives ' + x)
            nb_msg = nb_msg + 1
            p_out.send(x)
            sleep(random())
    except EOFError:
        pass
    print(name + ' ending ... ' + str(nb_msg) + ' message(s)')

if __name__ == '__main__':
    p1_in, p1_out = Pipe()
    p2_in, p2_out = Pipe()

    proc = []

    for i in range(3):
        p = Process(target=job, args=(str(i), p1_out, p2_in))
        p.start()
        proc.append(p)

    for x in range(10):
        p1_in.send(chr(97+x))
    p1_in.close()
    for p in proc:
        p.join()
    p1_out.close()
    p2_in.close()

    try:
        while True:
            print(p2_out.recv())
    except EOFError:
        pass

    p2_out.close()

0 个答案:

没有答案