间歇性smtp破裂管(错误32)

时间:2010-11-05 13:15:19

标签: python smtp smtplib

我有一个python脚本,它会在一天中定期使用smtplib发送几组电子邮件(到不同内容的不同地址)。有点频繁(比如在同一时间发送多批电子邮件的批次时大约是5次),我得到一个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服务器不是由我维护的,但应该维护得很好(用于~10k人组织)。我最初在发送每封电子邮件后连接并断开与smtpserver的连接,但这比这种方法产生的错误更多。

使用/ usr / sbin / sendmail而不是smtplib会更安全吗?

1 个答案:

答案 0 :(得分:1)

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流量,看看发生了什么。你有很多广泛的异常处理,不一定能向你显示确切的错误。