注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

一线天色 天宇星辰

天下武功,唯快不破

 
 
 

日志

 
 

java.net.BindException: Cannot assign requested address解决之道  

2011-12-08 22:35:58|  分类: 软件开发 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

最近让一位同事整理我们研发环境的机器,发现整理完毕之后,有些机器竟然启动不起来了。相关现象如下

java.net.BindException: Cannot assign requested address解决之道 - 一线天色 天宇星辰 - 一线天色 天宇星辰

 Dec 7, 2011 11:52:00 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 15913 ms
Dec 7, 2011 11:52:00 PM org.apache.catalina.core.StandardServer await
SEVERE: StandardServer.await: create[8005]:
java.net.BindException: Cannot assign requested address
        at java.net.PlainSocketImpl.socketBind(Native Method)
        at java.net.AbstractPlainSocketImpl.bind(AbstractPlainSocketImpl.java:353)
        at java.net.ServerSocket.bind(ServerSocket.java:336)
        at java.net.ServerSocket.<init>(ServerSocket.java:202)
        at org.apache.catalina.core.StandardServer.await(StandardServer.java:406)
        at org.apache.catalina.startup.Catalina.await(Catalina.java:676)
        at org.apache.catalina.startup.Catalina.start(Catalina.java:628)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:616)
        at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
        at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Dec 7, 2011 11:52:00 PM org.apache.coyote.http11.Http11Protocol pause
INFO: Pausing Coyote HTTP/1.1 on http-80
Dec 7, 2011 11:52:01 PM org.apache.coyote.http11.Http11Protocol pause
INFO: Pausing Coyote HTTP/1.1 on http-443
Dec 7, 2011 11:52:02 PM org.apache.catalina.core.StandardService stop
INFO: Stopping service Catalina

从日志我们可以看到,系统在绑定8005端口的时候,发现TCP8005端口无法创建,因此系统出现await并对应出现了pause,过了预设的超时时间还没有完成我们可以看到tomcat执行了stop的操作,所以很显然,tomcat没有启动成功!为什么会这样呢?

经过多次排查,发现tomcat在绑定数据的时候是绑定在localhost上面的,那么localhost的怎么可能出错的呢?

难道是hosts?

果断排查hosts,果然发现了问题?谁把127.0.0.1 localhost这段windows自带的去掉了?

于是果断加上这个

127.0.0.1 localhost

再次运行,果然这次成功启动了!

这时候查询进程对应的绑定端口,如下图所示:

java.net.BindException: Cannot assign requested address解决之道 - 一线天色 天宇星辰 - 一线天色 天宇星辰

 我们看到,8005端口绑定了localhost解析的对应的IP 127.0.0.1 本机启动成功!

如此一来,我们来想一个问题,如果是这么解析的,那我们将localhost对应的解析IP换成其他的IP会怎么样的呢?是不是会正常启动的呢?

  评论这张
 
阅读(15985)| 评论(4)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017