Tomcat Cannot assign requested address: JVM_Bind 非端口占用衝突

  啓動tomcat,錯誤信息如下:

嚴重: StandardServer.await: create[8005]: 
java.net.BindException: Cannot assign requested address: JVM_Bind
	at java.net.PlainSocketImpl.socketBind(Native Method)
	at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:359)
	at java.net.ServerSocket.bind(ServerSocket.java:319)
	at java.net.ServerSocket.(ServerSocket.java:185)
	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:39)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
	at java.lang.reflect.Method.invoke(Method.java:597)
	at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
	at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
  年前程序好好的,怎麼年後第一天tomcat咋啓動失敗呢?難道tomcat也沒有從假期調整過來?

  使用DOS命令netstat -an查看被佔用的端口,並未發現有任何程序佔用Tomcat使用的相關端口(例如8080),並且將Tomcat安裝目錄下的conf/server.xml文件中的端口改爲其他端口,再次運行也無法正常啓動。

  通過測試,可以初步判斷應該不是端口占用引起的問題。

  如果不是端口占用的問題的話,那麼就要考慮是否是IP綁定的問題了。

  查看hosts文件:C:\Windows\System32\drivers\etc\hosts


127.0.0.1       localhost
169.196.254.14    localhost

  把第二行ip去掉,再次啓動,正常啓動。

 在服務器領域,一臺計算機配置多個IP地址是比較常見的。Tomcat在啓動時,會根據配置去獲取所有的IP地址,並且進行逐個綁定,當發現需要綁定的IP地址不存在時,將會觸發上述異常,從而導致無法正常啓動。

 原來公司電腦ip是動態分配的啊,原來曾經年前配置的ip,年後竟然失效,導致異常出現。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章