我有一个包含多个主机的小域。Sendmail 设置为将所有本地生成的邮件(主要是root@localhost
由 cron 作业生成的邮件)转发到中央“邮件中心”,使用
define(`MAIL_HUB', `somehost.mydomain.org')
在sendmail.mc
. 最近我在远程端的邮件服务器出现问题,所以它不会接受来自该主机的邮件。这导致 sendmail 丢弃所有邮件。来自/var/log/maillog
:
sendmail[3133]: n4461S5s003133: n4461S5t003133: return to sender: Service unavailable
sendmail[3133]: n4461S5t003133: to=root, delay=00:00:00, xdelay=00:00:00, mailer=relay, pri=34772, relay=XXXXX.org. [91.184.38.153], dsn=5.0.0, stat=Service unavailable
sendmail[3133]: n4461S5s003133: Losing ./qfn4461S5s003133: savemail panic
在此期间生成的所有邮件都被丢弃并永远丢失。
我怎样才能防止这种情况?理想情况下,我希望 sendmail 再试一次,或者最终将邮件保存到本地文件作为最后的手段。
您的服务器几乎在这里做了“正确”的事情。
远端返回“5xx”类错误消息,表示永久无法传递消息,因此您的端完全中止了传递。
为了让您的服务器继续对消息进行排队,它必须收到“4xx”类消息,表示暂时失败。
但是,为了防止邮件永远丢失,您需要确定导致“保存邮件恐慌”错误的原因——它们应该刚刚被退回给发件人。
通常,
sendmail
应该将任何失败的发送尝试保存在本地假脱机文件中并重试最多五天,因此可能存在一些配置错误。根据这些参考资料:你需要确保你没有(来自上面的参考资料):
/etc/aliases
mbox
文件超过 2GB,procmail
无法投递电子邮件此外,请确保您没有遇到
selinux
问题。可能selinux
是阻止sendmail
保存文件。电子邮件永远不应该完全丢失——在最坏的情况下,它应该被退回给原始发件人和邮政主管。如果电子邮件完全丢失,则可能是配置错误或 sendmail 中的错误。在上下文中,此错误的含义是
sendmail
尝试在假脱机文件中传递消息,./qfn4461S5s003133
但远程邮件服务器返回错误响应“服务不可用”。因此,本地sendmail
试图退回电子邮件。尝试这样做时出了点问题,因此放弃了电子邮件。这是 CPU 的双总线故障的电子邮件等价物。也就是说,发生致命错误(无法保存或退回电子邮件)以响应致命错误(远程服务器不可用的时间足够长,以至于 sendmail 放弃重试)。