在多个进程中使用imaplib.IMAP4_SSL

时间:2018-02-28 22:01:37

标签: python sockets multiprocessing imaplib

我想在许多进程中重用imaplib.IMAP4_SSL实例,因此我不必多次登录。 这是一些代码:

import imaplib
from multiprocessing import Process

def fetch(mail_client):
    mail_client.uid('fetch', b'1', 'BODY[TEXT]')

def main():
    c = imaplib.IMAP4_SSL('imap.gmail.com')
    c.login(user='**', password='***')
    c.select('inbox')

    procs = [Process(target=fetch, args=(c,)) for _ in range(100)]
    for p in procs:
        p.start()

    for p in procs:
        p.join()

if __name__ == '__main__':
    main()

但是我得到了与socket相关的错误:

  

imaplib.IMAP4.abort:套接字错误:[Errno 32]管道损坏

我认为这是因为进程正在写入imaplib.IMAP4_SSL所具有的同一个套接字,所以我尝试添加multiprocessing.Lock以防止同时访问:

import imaplib
from multiprocessing import Process, Lock


def fetch(mail_client, lock):
    with lock:
        mail_client.uid('fetch', b'1', 'BODY[TEXT]')


def main():
    c = imaplib.IMAP4_SSL('imap.gmail.com')
    c.login(user='engineering@epallet.com', password='Qwe=1dSAzxc+%')
    c.select('inbox')
    lock = Lock()

    procs = [Process(target=fetch, args=(c, lock)) for _ in range(100)]
    for p in procs:
        p.start()

    for p in procs:
        p.join()


if __name__ == '__main__':
    main()

但错误仍然存​​在。 一些进一步的调查表明,第一个进程成功调用mail.uid,但第二个进程无论如何都会调用imaplib.IMAP4.abort: command: UID => socket error: EOF

我使用的是Ubuntu 16.04。 任何建议都非常感谢。

更新:在stacktrace中发现了另一个异常,可能会导致所有其他异常:

  

ssl.SSLError:[SSL:DECRYPTION_FAILED_OR_BAD_RECORD_MAC]解密失败或记录错误mac(_ssl.c:2217)`

似乎这个问题是相关的 Python ssl problem with multiprocessing

2 个答案:

答案 0 :(得分:2)

你做不到。进程之间不共享SSL上下文;没有它,加密状态就会失去同步。

如果您需要在同一个IMAP收件箱中执行多个并发操作,则需要与服务器建立多个连接。

答案 1 :(得分:0)

似乎是SSL的问题。 SSL包装的套接字不能在多个进程上重用。我现在正在使用线程,没有Lock就一切正常。