出现这个问题,是系统利用 javamail 组件发送邮件,
Javamail 在提取本地 hostname 的时候会 dig 改 hostname ,然后以改 ip 发送邮件。
由于 hostname 对应的 ip 地址, linux 无法解析(如果是 windows 则无这个问题, windows 利用 netbios 协议去获得该主机的 ip 地址)到本机 hostname 的 ip ,导致 javamail 无法调用发送 ip 。 Postfix 收到此类邮件将拒绝投递,而产生 501 错误。
解决办法:
在有利用到 javamail 的所有主机重写 hosts 文件或者在 dns 服务器上设置该主机名的 ip 就可以解决这个问题。
这个错误的javamail 在发送helo 命令的时候找不到 hostname,直接发送helo命令
所以postfix返回了 501 Syntax: HELO hostname
javamail 首先会按顺序从下面两个key从session里找 hostname
mail.smtp.localhost
mail.smtp.localaddress
找不到的话会使用 InetAddress.getLocalHost() 得到 一个InetAddress
对象再getCanonicalHostName()
在修改hosts之前呢,
InetAddress.getLocalHost() 会抛出
Exception in thread "main" java.net.UnknownHostException: ui41.greenemls.org: ui41.greenemls.org
at java.net.InetAddress.getLocalHost(InetAddress.java:1353)
这个异常,然后返回null
也就是说不改的话,不单是邮件发不出去,如果有其他地方可能用到InetAddress.getLocalHost()的方法都可能抛出UnknownHostException
另外把javamail升级到1.4.3就可以的原因是
在1.4.3的javamail 里,会catch UnknownHostException 并根据当前跟smtp创建socket所使用的ip
getCanonicalHostName()得到hostname
但是这个得到的hostname