Exim - 很多没有发件人的冻结邮件

时间:2013-06-18 09:45:56

标签: exim

我是Exim的新手,我将它用作智能主机(从用户那里收回电子邮件并发送给我的ISP)。 enter image description here

系统工作正常,但我对冻结的邮件有一些问题。我有时会看队列而且有一些没有发件人的冻结邮件,所以Exim无法发送它们,因为如果没有发件人,它就无法通过ISP进行身份验证。

我可以从哪里开始调试?

非常感谢。

3 个答案:

答案 0 :(得分:23)

这些是退回邮件。有些东西是通过您的邮件服务器发送邮件,但收件人不接受它,因此您的系统会生成退回邮件。这些反弹信息也被拒绝,因此它们被外部MTA“冻结”。您需要弄清楚消息来自何处,并停止这些未经授权的消息流。

exigrep 1UorWC-0002Nz-Mz /var/log/exim/main.log(或无论你的路径是什么)

这将在邮件日志中找到退回邮件。我在邮件队列中选择了一条冻结的邮件作为示例(1UosOk-0000ej-KG):

# exigrep 1UosOk-0000ej-KG /var/log/exim/main.log
+++ 1UosOk-0000ej-KG has not completed +++
2013-06-18 09:40:22 1UosOk-0000ej-KG <= <> R=1UosOf-0000bX-BV U=www P=local S=894 
2013-06-18 09:40:24 1UosOk-0000ej-KG ** origsender@example.biz P=<> R=dnslookup_forwarder 
  T=remote_smtp_forwarder: SMTP error from remote mail server after RCPT TO:<origsender@example.biz>: 
  host mail.example.biz [80.76.197.72]: 554 5.7.1 <origsender@example.biz>: Relay access denied
2013-06-18 09:40:24 1UosOk-0000ej-KG Frozen (delivery error message)

第一行显示反弹消息 1UosOk-0000ej-KG 是为响应消息 1UosOf-0000bX-B 而创建的(这就是R =短语中的内容) &lt; = line表示)。现在搜索 THAT 消息ID以找出此消息实际来自何处。在我的情况下,它不是反弹消息,它是客户的自动回复:

# exigrep 1UosOf-0000bX-BV /var/log/exim/main.log
2013-06-18 09:40:18 1UosOf-0000bX-BV H=example.biz [62.189.29.157] Warning: SPF PASS (pass) to m.ivenue.com: 
  domain of example.biz designates 62.189.29.157 as permitted sender
2013-06-18 09:40:22 1UosOf-0000bX-BV <= origsender@example.biz H=example.biz [62.189.29.157] P=esmtp S=17624
2013-06-18 09:40:22 1UosOf-0000bX-BV => /netapp3/mail/maildirs/b/o/y/boyexample.com/sarah/Maildir/ 
  (sarah@boyexample.com) <sarah@boyexample.com> P=<origsender@example.biz> R=virtual_user T=address_directory
2013-06-18 09:40:22 1UosOf-0000bX-BV => sarah <sarah@boyexample.com> P=<origsender@example.biz> 
  R=autoresponder_always T=autoresponder_always_t
2013-06-18 09:40:22 1UosOf-0000bX-BV Completed

一旦您发现正在使用哪个进程通过您的系统发送这些消息,您就可以采取措施来阻止它们,假设它们不是有效的消息。你采取的步骤在很大程度上取决于你找到的东西。

通常您不想尝试重新发送这些冻结的邮件。但是,如果由于某些临时网络或配置错误导致消息被冻结,并且您希望让exim重新发送它们,那么您需要生成冻结消息列表并告诉Exim传递它们。最简单的方法是使用exiqgrep程序:

exiqgrep -z -i | xargs -n 1 exim -M

答案 1 :(得分:13)

冻结的邮件在exim队列中没用。您可以删除所有这些以减少exim队列列表。

以下命令将删除所有冻结的邮件:

exim -bpr | grep frozen | awk {'print $3'} | xargs exim -Mrm

exiqgrep -z -i | xargs exim -Mrm

如果您要删除超过特定时间的冻结邮件,例如24小时:

exiqgrep -zi -o 86400 | xargs exim -Mrm

86400代表24小时秒。这可以相应地改变。

答案 2 :(得分:5)

通过将配置选项ignore_bounce_errors_after设置为合适的值,exim可以自动清除冻结跳出,例如

ignore_bounce_errors_after = 12h

会在12小时后自动删除这些退回错误。