萬盛學電腦網

 萬盛學電腦網 >> 數據庫 >> mysql教程 >> Tomcat Cannot assign requested address: JVM_Bind 非端口占用沖突

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

最近朋友遇到在安裝並啟動Tomcat 6.0時,發現一直無法正確啟動。Tomcat在啟動時,會根據配置去獲取所有的IP地址,並且進行逐個綁定,當發現需要綁定的IP地址不存在時,將會觸發上述異常,從而導致無法正常啟動。

最近朋友遇到在安裝並啟動Tomcat 6.0時,發現一直無法正確啟動,主要異常堆棧信息如下:

 代碼如下復制代碼

嚴重: 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 6.0 是官方免安裝版本,並且是剛剛才下載的,因此不應該是文件缺失的問題。

根據異常信息推測,可能是Tomcat需要綁定的端口或某些資源被其他應用程序占用。

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

通過多種測試,可以初步判斷應該不是端口占用引起的問題。如果不是端口占用的問題的話,那麼就要考慮是否是IP綁定的問題了。

經過檢查,在朋友的服務器計算機的C:\Windows\System32\drivers\etc\hosts文件中發現如下部分內容:

127.0.0.1   localhost

169.196.254.14 localhost

169.196.254.14是一個不存在的本地IP地址,將hosts文件中的第二行內容169.196.254.14 localhost去掉後,再次啟動Tomcat,發現運行正常!

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

 代碼如下復制代碼

//輸出localhost映射的所有IP地址

InetAddress[] ips = InetAddress.getAllByName("localhost");

if(ips !=null) {

  for(InetAddress ip : ips) {

    System.out.println(ip.getHostAddress());

  }

}

/* 修改上述hosts文件前,輸出:

* 169.196.254.14

* 127.0.0.1

* 修改文件後,輸出

* 127.0.0.1

*/

 

copyright © 萬盛學電腦網 all rights reserved