tomcat启动时出现Address already in use: JVM_Bind(端口冲突) 的原因是因为端口被占用,有可能是因为多次启动tomcat或者启动了多个tomcat,或者是其他应用程序或者服务占用了。
错误日志如下:
严重: StandardServer.await: create[8005]:
java.net.BindException: Address already in use: 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 org.apache.catalina.core.StandardServer.await(StandardServer.java:373)
at org.apache.catalina.startup.Catalina.await(Catalina.java:662)
at org.apache.catalina.startup.Catalina.start(Catalina.java:614)
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)
通过这一句话:严重: StandardServer.await: create[8005]:我们知道8005端口被占用了,那么解决方案就很简单了,关闭掉现在占用8005端口的程序即可。
(1)cmd进入dos
(2)netstat -ano找到 8005端口对应的pid(例如 2006)或者netstat -ano|findstr 8005
(3)taskkill /f /t pid 2006
至于taskkill这些指令的格式使用,可以查询网上资料。
tomcat启动报错:Address already in use: JVM_Bind(端口冲突)
原文地址:http://blog.csdn.net/chentravelling/article/details/46280157