我有一个 python 脚本,它在一天中定期使用 smtplib 发送几组电子邮件(发送到具有不同内容的不同地址)。有点频繁(说大约五分之一的时候同时发送一批以上的电子邮件),我得到一个 IOError (errno:损坏的管道)。我尝试重置并退出 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 会更安全吗?