天天看點

java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind 處理方法

今天部署項目過程中tomcat報如下異常:

java.net.SocketException: Unrecognized Windows Sockets error: 0: 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.<init>(ServerSocket.java:185) 

    at java.net.ServerSocket.<init>(ServerSocket.java:141) 

    at org.apache.tomcat.util.net.DefaultServerSocketFactory.createSocket(DefaultServerSocketFactory.java:50) 

    at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:494) 

    at org.apache.tomcat.util.net.JIoEndpoint.start(JIoEndpoint.java:513) 

    at org.apache.coyote.http11.Http11Protocol.start(Http11Protocol.java:202) 

    at org.apache.catalina.connector.Connector.start(Connector.java:1132) 

    at org.apache.catalina.core.StandardService.start(StandardService.java:457) 

    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710) 

    at org.apache.catalina.startup.Catalina.start(Catalina.java:552) 

    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:288) 

    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413) 

2012-11-27 17:13:51 org.apache.catalina.startup.Catalinastart 

Google下發現原來是端口被占用。對于這個異常其實很容易解決,不外乎兩種解決方法:

    1、更改tomcat端口

       2、  關掉占用該端口的程序。

一、更改tomcat端口

          首先到安裝目錄(或者解壓目錄)下找到conf檔案夾,在裡面找到server.xml的檔案,找到

<Connector

port="8080"

maxThreads="150"

minSpareThreads="25"

maxSpareThreads="75" 

enableLookups="false"

redirectPort="8443"

acceptCount="100" 

debug="0"

connectionTimeout="20000"  

disableUploadTimeout="true"

/> 

将port="8080"改為其它的就可以了

          二、關閉占用該端口的程序

1、首先進入指令行檢視端口是否被占用

使用指令: netstat –ano。如下:

java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind 處理方法

我的伺服器端口是:8080。從上面可以看出8080端口已經被PID為5268的程序占用。

           2、檢視該PID為5268的程序

使用指令:tasklist|findstr "5268"。如下

java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind 處理方法

從上面看出PID為5268的程序為javaw.exe。

第一種解決辦法是:把javaw.exe程序關掉

第二種解決辦法是:直接通過任務管理器檢視PID為5268的程序,然後關掉windows任務管理器->檢視->選擇列選中PID然後檢視任務管理器,關掉PID為5268的程序。

繼續閱讀