質問

SMTPlibを1日を通して定期的に使用して、いくつかのメール(異なるコンテンツの異なるアドレスに)を送信するPythonスクリプトがあります。やや頻繁に(同時に複数の電子メールのバッチを送信するときに5倍の約1倍)、ioerror(errno:壊れたパイプ)を取得します。 SMTPサーバーをリセットして終了してから、再度サーバーに接続して再送信を試みますが、最初に失敗した場合は常に失敗します(同じ例外を除く)。 SMTPサーバーは大学によって維持されており、信頼できる必要があります(イントラネット上にある限り、ログインレスメールを許可します)。

以下のコードのugさ(乾燥の欠如)を無視すると、誰もがより信頼できる接続方法を提案できますか?

Member Function 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から接続および切断されましたが、この方法よりも多くのエラーが発生しました。

また、smtplibではなく/usr/sbin/sendmailを使用する方が安全ですか?

役に立ちましたか?

解決

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帰属
所属していません StackOverflow
scroll top