私は、smtplibを使用して1日を通して定期的に数セットの電子メールを(異なる内容の異なるアドレスに)送信するPythonスクリプトを持っています。やや頻繁に(複数の電子メールのバッチを同時に送信する場合は約5回に1回)、IOError(エラー番号:パイプの破損)が発生します。SMTPサーバーをリセットして終了してから、サーバーに再接続して再送信を試みますが、最初に失敗した場合は常に失敗します(同じ例外を除きます)。SMTPサーバーは大学によって維持されており、信頼できる必要があります(そして、イントラネット上にいる限り、ログインのない電子メールを許可します)。
以下のコードの醜さ(DRYの欠如)を無視して、誰かがより信頼性の高い接続方法を提案できますか?
メンバー関数send_emailsを持ついくつかの電子メールのバッチを送信するEmailSetというクラスを作成します。
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サーバーは私によって保守されていませんが、適切に保守されている必要があります(最大10,000人の組織に使用されます)。私は元々、各電子メールを送信した後にsmtpserverに接続および切断しましたが、この方法よりも多くのエラーが発生しました。
また、smtplibよりも/ usr / sbin / sendmailを使用する方が安全ですか?