当前位置: 首页 > 图文教程 > 服务器 > 服务器其他 > Tomcat 启动错误(8080端口被占用)处理方法

服务器其他
注意: 您的主控服务器上安装IE7,会造成新网互联的接口不正常
注册新网的域名所有出错的代码解说
主控端与受控端升级的常见问题
使用“新网”接口的用户注意问题
建议的服务器分区办法
域名涨价以后,如何修改代理成本价?
域名注册失败的处理办法
单独重开一个网站的步骤
使用BAK文件还原SQL2000出错的原因
开通一个数据库失败的原因的和解决办法
远程无法连接SQL2000及MySQL的原因和解决办法
我的服务器SQL2000的sqlserver占用了90%的cpu,怎么查是那个库?
“SQL2000数据库”运行在普通用户下所需的权限
注册新网互联的域名所有出错的代码解说
能否批量把网站从一台服务器移到哪一台服务器
开通虚拟主机时提示Server.CreateObject失败的解决办法
邮箱网站不能用mail.xxx.com:8888的方式访问原因
代理模板与主站模板的常见问题
星外科技每天自动备份SQL2000/Mysql的工具
服务器 安全检查要点[星外提供]

服务器其他 中的 Tomcat 启动错误(8080端口被占用)处理方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-04   浏览: 379 ::
收藏到网摘: n/a

8080端口被占用的解决方法,其实这个方法,可以用于其它一些端口被占用的问题。

错误描述:
2009-7-12 15:40:35 org.apache.coyote.http11.Http11BaseProtocol start
严重: Error starting endpoint
java.net.BindException: Address already in use: JVM_Bind:8080
at org.apache.tomcat.util.net.PoolTcpEndpoint.initEndpoint(PoolTcpEndpoint.java:298)
at org.apache.tomcat.util.net.PoolTcpEndpoint.startEndpoint(PoolTcpEndpoint.java:313)
at org.apache.coyote.http11.Http11BaseProtocol.start(Http11BaseProtocol.java:151)
at org.apache.coyote.http11.Http11Protocol.start(Http11Protocol.java:76)
at org.apache.catalina.connector.Connector.start(Connector.java:1090)
at org.apache.catalina.core.StandardService.start(StandardService.java:457)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
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:585)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)
2009-7-12 15:40:35 org.apache.catalina.startup.Catalina start
严重: Catalina.start:
LifecycleException: service.getName(): "Catalina"; Protocol handler start failed: java.net.BindException: Address already in use: JVM_Bind:8080
at org.apache.catalina.connector.Connector.start(Connector.java:1097)
at org.apache.catalina.core.StandardService.start(StandardService.java:457)
at org.apache.catalina.core.StandardServer.start(StandardServer.java:700)
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:585)
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:295)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:433)
2009-7-12 15:40:35 org.apache.catalina.startup.Catalina start
信息: Server startup in 9860 ms
关键信息:
java.net.BindException: Address already in use: JVM_Bind:8080
错误原因:
8080端口被其他的应用占用!
解决方案:
第一步,命令提示符号,执行命令:netstat –ano
Active Connections
Proto Local Address Foreign Address State PID
TCP 0.0.0.0:8080 0.0.0.0:0 LISTENING 656
TCP 0.0.0.0:8080 0.0.0.0:0 LISTENING 656
可见,占用8080端口的进程的PID是656
第二步,命令提示符号,执行命令:tasklist
图像名 PID 会话名 会话# 内存使用
========================= ====== ================ ======== ============
TNSLSNR.exe 656 Console 0 8,992 K
可见,该占用8080端口的进程是TNSLSNR.exe
第三步,通过任务管理器,终止进程TNSLSNR.exe
第四步,重新启动tomcat,即可正常启动