Tomcat Cannot assign requested address: JVM_Bind

昨天啓動 Tomcat 7.0 或者 Tomcat 8.0 時,壹直沒法正確啓動,不管是經過命令行調用批處理腳本仍是在 Eclipse 中集成以後再啓動,所有都會提示以下異常堆棧信息:java

嚴重: 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 7.0 和 Tomcat 8.0 在此以前都是工做正常沒有出過問題,因此能夠確認安裝包沒有問題。apache

然而根據異常信息推測,多是 Tomcat 須要綁定的端口或某些資源被其餘應用程序佔用。在網上搜索了下,嘗試 DOS 命令 netstat -an 查看被佔用的端口,並未發現有任何程序佔用 Tomcat 使用的相關端口(例如8080),而且將Tomcat安裝目錄下的 conf/server.xml 文件中的端口改成其餘端口,再次運行也沒法正常啓動。服務器

經過多種測試,能夠初步判斷應該不是端口占用引發的問題。若是不是端口占用的問題的話,那麼就要考慮是不是IP綁定的問題了。socket

通過檢查,在文件 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,發現運行正常!.net

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

若是想知道某臺機器上的 localhost 綁定了哪幾個 IP 地址,可使用以下 Java 代碼來簡單的輸出結果。code

//輸出 localhost 映射的全部IP地址 
InetAddress[] ips = InetAddress.getAllByName("localhost"); 
if (ips != null) {     
	for (InetAddress ip : ips) {         
		System.out.println(ip.getHostAddress());     
	} 
}

把 127.0.0.1  localhost 之外的其它映射刪除以後,再重啓 Tomcat ,問題解決。server

相關文章
相關標籤/搜索