设为首页 收藏本站
查看: 1188|回复: 0

[经验分享] java.net.SocketException: Unrecognized Windows Sockets error: 0: JVM_Bind 处理方法

[复制链接]

尚未签到

发表于 2016-5-24 11:35:42 | 显示全部楼层 |阅读模式
今天部署项目过程中tomcat报如下异常:
[html]
view plaincopyprint?





  • 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




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的文件,找到


[html]
view plaincopyprint?





  • <Connector
    port="8080"
    maxThreads="150"
    minSpareThreads="25"
    maxSpareThreads="75"

  • enableLookups="false"
    redirectPort="8443"
    acceptCount="100"

  • debug="0"
    connectionTimeout="20000"

  • disableUploadTimeout="true"
    />



<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。如下:

   DSC0000.jpg
  
我的服务器端口是:
8080。从上面可以看出8080端口已经被PID5268的进程占用。

  
2、查看该PID5268的进程

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

   DSC0001.jpg
  
从上面看出
PID5268的进程为javaw.exe

  
第一种解决办法是:把
javaw.exe进程关掉

  
第二种解决办法是:直接通过任务管理器查看
PID5268的进程,然后关掉
windows任务管理器->查看->选择列选中PID然后查看任务管理器,关掉PID5268的进程。
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-221163-1-1.html 上篇帖子: CMDN Club #19: Windows 8 Dev BootCamp 下篇帖子: 如何在Windows服务器上实现最佳文件访问监控
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表