Tomcat Cannot assign requested address: JVM_Bind 非端口占用沖突
前言:
最近朋友遇到在安裝并啟動(dòng)Tomcat 6.0時(shí),發(fā)現(xiàn)一直無(wú)法正確啟動(dòng),主要異常堆棧信息如下:
嚴(yán)重: 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 是官方免安裝版本,并且是剛剛才下載的,因此不應(yīng)該是文件缺失的問(wèn)題。
根據(jù)異常信息推測(cè),可能是Tomcat需要綁定的端口或某些資源被其他應(yīng)用程序占用。
使用DOS命令netstat -an查看被占用的端口,并未發(fā)現(xiàn)有任何程序占用Tomcat使用的相關(guān)端口(例如8080),并且將Tomcat安裝目錄下的conf/server.xml文件中的端口改為其他端口,再次運(yùn)行也無(wú)法正常啟動(dòng)。
通過(guò)多種測(cè)試,可以初步判斷應(yīng)該不是端口占用引起的問(wèn)題。如果不是端口占用的問(wèn)題的話(huà),那么就要考慮是否是IP綁定的問(wèn)題了。
經(jīng)過(guò)檢查,在朋友的服務(wù)器計(jì)算機(jī)的C:\Windows\System32\drivers\etc\hosts文件中發(fā)現(xiàn)如下部分內(nèi)容:
127.0.0.1 localhost 169.196.254.14 localhost
169.196.254.14是一個(gè)不存在的本地IP地址,將hosts文件中的第二行內(nèi)容169.196.254.14 localhost去掉后,再次啟動(dòng)Tomcat,發(fā)現(xiàn)運(yùn)行正常!
在服務(wù)器領(lǐng)域,一臺(tái)計(jì)算機(jī)配置多個(gè)IP地址是比較常見(jiàn)的。Tomcat在啟動(dòng)時(shí),會(huì)根據(jù)配置去獲取所有的IP地址,并且進(jìn)行逐個(gè)綁定,當(dāng)發(fā)現(xiàn)需要綁定的IP地址不存在時(shí),將會(huì)觸發(fā)上述異常,從而導(dǎo)致無(wú)法正常啟動(dòng)。
//輸出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 */
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
相關(guān)文章
JavaWeb利用struts實(shí)現(xiàn)文件下載時(shí)改變文件名稱(chēng)
這篇文章主要為大家詳細(xì)介紹了JavaWeb利用struts實(shí)現(xiàn)文件下載時(shí)改變文件名稱(chēng)的相關(guān)資料,需要的朋友可以參考下2016-06-06Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(53)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-08-08淺談兩個(gè)jar包中包含完全相同的包名和類(lèi)名的加載問(wèn)題
下面小編就為大家?guī)?lái)一篇淺談兩個(gè)jar包中包含完全相同的包名和類(lèi)名的加載問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09Spark學(xué)習(xí)筆記之Spark中的RDD的具體使用
這篇文章主要介紹了Spark學(xué)習(xí)筆記之Spark中的RDD的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Maven dependencyManagement元素標(biāo)簽的具體使用
在Maven中dependencyManagement的作用其實(shí)相當(dāng)于一個(gè)對(duì)所依賴(lài)jar包進(jìn)行版本管理的管理器,本文主要介紹了Maven dependencyManagement元素標(biāo)簽的具體使用,感興趣的可以了解一下2024-03-03JAVA如何把數(shù)據(jù)庫(kù)的數(shù)據(jù)處理成樹(shù)形結(jié)構(gòu)
本文介紹了JAVA如何把數(shù)據(jù)庫(kù)的數(shù)據(jù)處理成樹(shù)形結(jié)構(gòu),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09SpringMVC 實(shí)現(xiàn)用戶(hù)登錄實(shí)例代碼
這篇文章主要介紹了SpringMVC 實(shí)現(xiàn)用戶(hù)登錄實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下2017-02-02SpringBoot核心@SpringBootApplication使用介紹
這篇文章主要介紹了SpringBoot核心@SpringBootApplication的使用,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03關(guān)于QueryWrapper高級(jí)使用示例
本文介紹了QueryWrapper的高級(jí)使用方法,包括查詢(xún)指定字段、使用MySQL函數(shù)處理字段、設(shè)置查詢(xún)限制等,通過(guò)select()可查詢(xún)指定字段并處理,last()方法實(shí)現(xiàn)limit效果,apply()可在查詢(xún)條件中使用函數(shù),這些技巧有助于提升數(shù)據(jù)庫(kù)操作的靈活性和效率2024-09-09