MySQL 本身并不提供内置的邮件发送功能,但你可以使用第三方工具或编写自定义脚本来实现邮件发送,并加入自动重试的逻辑。
以下是一个简单的示例,展示如何使用 Python 的 smtplib
库发送邮件,并在发送失败时进行自动重试:
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart import time def send_email(smtp_server, port, sender_email, sender_password, receiver_email, subject, body): msg = MIMEMultipart() msg['From'] = sender_email msg['To'] = receiver_email msg['Subject'] = subject msg.attach(MIMEText(body, 'plain')) try: server = smtplib.SMTP(smtp_server, port) server.starttls() server.login(sender_email, sender_password) text = msg.as_string() server.sendmail(sender_email, receiver_email, text) server.quit() print("邮件发送成功") except Exception as e: print(f"邮件发送失败,错误信息:{e}") print("将在 5 秒后重试...") time.sleep(5) send_email(smtp_server, port, sender_email, sender_password, receiver_email, subject, body) # 使用示例 smtp_server = 'smtp.example.com' port = 587 sender_email = 'your_email@example.com' sender_password = 'your_email_password' receiver_email = 'receiver@example.com' subject = '测试邮件' body = '这是一封测试邮件' send_email(smtp_server, port, sender_email, sender_password, receiver_email, subject, body)
请注意,上述示例仅用于演示目的,实际使用时你需要将 smtp_server
、port
、sender_email
和 sender_password
替换为实际的值。此外,为了安全起见,建议使用环境变量或配置文件来存储敏感信息,而不是直接写在脚本中。
在上述示例中,如果邮件发送失败,脚本会在 5 秒后自动重试。你可以根据需要调整重试的时间间隔和重试次数。