最近java取IP地址抛异常。 经查询发现 /etc/hosts中 没有配置 hostname, 导致hostname 无法解析到IP地址
否则 java.net.InetAddress.getLocalHost 会抛出 java.net.UnknownHostException 异常。
出现这个问题,是系统利用 mail.jar 组件发送邮件,
Javamail 在提取本地 hostname 的时候会 dig 该 hostname ,然后以该 ip 发送邮件。
由于 hostname 对应的 ip 地址, linux 无法解析(如果是 windows 则无这个问题, windows 利用 netbios 协议去获得该主机的 ip 地址)到本机 hostname 的 ip ,导致 javamail 无法调用发送 ip 。
解决办法:
在有利用到 javamail 的所有主机重写 hosts 文件或者在 dns 服务器上设置该主机名的 ip 就可以解决这个问题。
如自己在code里面set写localhost:
MimeMessage message = null;
props.put("mail.smtp.host", "mail.pccw.com");
props.put("mail.smtp.localhost", "localHostAdress");
props.put("mail.smtp.port", "25");
props.put("mail.smtp.auth", "false");
message = new MimeMessage(sendsession);
如上面加背景色的代码就可以解决这个问题。
这个错误的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