我想在许多进程中重用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
答案 0 :(得分:2)
你做不到。进程之间不共享SSL上下文;没有它,加密状态就会失去同步。
如果您需要在同一个IMAP收件箱中执行多个并发操作,则需要与服务器建立多个连接。
答案 1 :(得分:0)
似乎是SSL的问题。 SSL包装的套接字不能在多个进程上重用。我现在正在使用线程,没有Lock就一切正常。