天天看点

InetAddress.getLocalHost() java.net.UnknownHostException 异常

from: http://www.360doc.com/content/10/1118/18/2703996_70480884.shtml

昨天备机在连接ActiveMQ

的时候出现了“Reason: java.net.UnknownHostException: zw_65_43:”这样一个异常,上次碰到这个问题的时候只是在测试组的测试机器上,四台正式机都是对的,没有关注。

问题原因是在系统的 /etc/Hostname中配置了“zw_65_43” 作为主机名,而在/etc/hosts文件中没有 相应的“zw_65_43”。简单的解决办法是

对应关系配好就可以,甚至删除/etc/Hostname这个文件也可以。

深层的原因: 在大多数Linux操作系统中,都是以/etc/hosts中的配置查找主机名的,但是 Detian based system用/etc/Hostname文件中的配置做主机名。

而Java 的InetAddress.java 调用 InetAddressImpl.java 的   public native String getLocalHostName() throws UnknownHostException; 来获取本地主机名, Java 的这个方法是native的,是本地系统的一个实现,所以在本地配置出现问题的情况下,Java 代码出现问题。

1. hostname 查看本机名称,

   a. 若本机名称不是一个IP地址, 比如是"sohu",则必须在/etc/hosts中配置 sohu对应本机IP,否则java.net.InetAddress.getLocalHost会抛出java.net.UnknownHostException异常.

   b. 若本机名称是一个IP地址,而且必须是本机某块网卡的IP, 

   c. 第三种情况比较麻烦。倘若本机名称是一个IP地址,但不是本机某块网卡的IP,或者只是某个IP地址的一部分,比如192.168(这是我遇到过的),那么执行java.net.InetAddress.getLocalHost().getHostAddress()会得到192.0.0.168,java.net.InetAddress.getLocalHost().getHostAddress()不会抛出异常,但相关访问会停滞很久,原因是他在查找192.0.0.168这个地址, 若网络中不存在这个地址,最终会抛出Connection timed out异常;若网络中存在这个地址,Connection refused to host这个异常将被抛出,这些显然都不是想要的

结论:

    1. 设置本机名称:hostname mName     xxx最好不是写IP地址的形式,若写则必须是本机的完全IP形式(不要只写一半)

    2. 在/etc/hosts里加一行 本机IP mName

    3. 用InetAddress.getLocalHost().getHostAddress()测试一下结果是否是与本机IP一致

继续阅读