簡體   English   中英

間歇式SMTP斷管(錯誤32)

[英]intermittent smtp broken pipe (errno 32)

我有一個python腳本,它整天定期使用smtplib發送幾組電子郵件(到具有不同內容的不同地址的電子郵件)。 有點頻繁(一次發送一批以上的電子郵件時,大約五分之一),我得到了IOError(錯誤:管道破損)。 我嘗試重置並退出SMTP服務器,然后再次連接到該服務器並嘗試重新發送,但是如果它第一次失敗(總是有同樣的例外),則總是失敗。 SMTP服務器由大學維護,並且應該可靠(只要您在Intranet上,就可以允許無登錄電子郵件)。

忽略下面代碼的丑陋(缺少DRY),有人可以建議一種更可靠的連接方式嗎?

我創建了一個名為EmailSet的類,該類將發送一批具有成員函數send_emails的電子郵件:

class EmailSet(object):
    ...
    def send_emails(self):
        try: # Connect to server
            server = smtplib.SMTP( smtp_server_name_str, 25)
            server.set_debuglevel(self.verbose)
            server.ehlo()
            for email in self.email_set:
                try: # send 1st mail
                    logging.debug("Sending email to %r" % email.recipients)        
                    response_dict = server.sendmail(email.fromaddr, email.recipients, email.msg_str())
                    logging.info("Sent email to %r" % email.recipients)        
                except Exception as inst:
                    logging.error('RD: %r' % response_dict)
                    logging.error("Email Sending Failed")
                    logging.error("%r %s" % ( type(inst), inst ) )
                    try: # send second mail
                        logging.info("Second Attempt to send to %r" % email.recipients)
                        try:
                            server.rset() 
                            server.quit()
                        except:
                            pass
                        time.sleep(60) # wait 60s
                        server = smtplib.SMTP( smtp_server_name_str, 25)
                        server.set_debuglevel(self.verbose)
                        server.ehlo()
                        response_dict = server.sendmail(email.fromaddr, email.recipients, email.msg_str())
                        logging.info("Sent email to %r (2nd Attempt)" % email.recipients)        
                    except Exception as inst:
                        try:
                            logging.error('RD: %r' % response_dict)
                        except:
                            pass
                        logging.error("Second Attempt Email Sending Failed")
        except:
            logging.debug("Can't connect to server")
        finally:
            logging.debug("Reseting and Quitting Server")
            server.rset()
            server.quit()
            logging.debug("Successfully Quit Server")
        return True

關於如何進行調試的任何想法? 我不維護stmp服務器,盡管應該維護良好(用於約1萬人組織)。 發送每封電子郵件后,我最初是從smtpserver連接和斷開的,但這種方法產生的錯誤更多。

使用/ usr / sbin / sendmail而不是smtplib會更安全嗎?

Also would it be safer to use /usr/sbin/sendmail rather than smtplib?

從處理消息隊列和重試隊列運行器的角度來看。 是的,sendmail或其他本地MTA可以為您解決此問題。

Any thoughts on how to proceed debugging this?

數據包捕獲。 使用wireshark捕獲SMTP流量,看看發生了什么。 您有很多廣泛的異常處理方法,不一定能向您顯示確切的錯誤。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM