之前使用mysql的时候,在配置文件中,已经指明了ip访问,但无论怎么写,得到的都是这个ip主机的别名,很无奈。直到把这台机器重装后,才彻底解决这个问题。当时没有多想,碰巧这台虚拟机的宿主机硬件故障需要重新配置,顺道解决了这个问题。
如今,配置Kestrel的Worker都是时候,遇到了这样的问题:
[2012-08-06 11:35:56,165][ERROR][net.rubyeye.xmemcached.monitor.XMemcachedMbeanServer:88] Get HostName Error
java.net.UnknownHostException: 49_114: 49_114
at java.net.InetAddress.getLocalHost(InetAddress.java:1354)
at net.rubyeye.xmemcached.monitor.XMemcachedMbeanServer.initialize(XMemcachedMbeanServer.java:84)
at net.rubyeye.xmemcached.monitor.XMemcachedMbeanServer.<init>(XMemcachedMbeanServer.java:73)
at net.rubyeye.xmemcached.monitor.XMemcachedMbeanServer.<clinit>(XMemcachedMbeanServer.java:66)
这里的49_114是这台机器的hostname,而我要访问的是另一个ip。并发我的代码访问了localhost,可能xmemcached默认初始化时,进行了本机信息获取,才导致这一问题。
看看hostname是谁:
引用
$ hostname
49_114
$ hostname -i
hostname: 未知的主机
太悲剧了 ,难怪出现Get HostName Error!
再看看hosts
引用
cat /etc/hosts
# Do not remove the following line, or various programs
# that require network functionality will fail.
127.0.0.1 localhost.localdomain localhost
::1 localhost6.localdomain6 localhost6
这就是悲剧的根源,在hosts中,没有指明自身ip绑定。
这个问题其实很容易解决,将hostname与localhost绑定即可。
引用
# Do not remove the following line, or various programs
# that require network functionality will fail.
127.0.0.1 49_114 localhost.localdomain localhost
::1 localhost6.localdomain6 localhost6
就这么简单!
引用
$ hostname
49_114
$ hostname -i
127.0.0.1
这时候,就不会再出来Get HostName Error异常了!