|
启动tomcat报StandardServer.await: create[8005]
今天发现朋友在启动tomcat时出现以下错误
2012-5-9 8:58:26 org.apache.coyote.http11.Http11AprProtocol start
INFO: Starting Coyote HTTP/1.1 on http-8080
2012-5-9 8:58:26 org.apache.coyote.ajp.AjpAprProtocol start
INFO: Starting Coyote AJP/1.3 on ajp-8009
2012-5-9 8:58:26 org.apache.catalina.startup.Catalina start
INFO: Server startup in 4218 ms
2012-5-9 8:58:26 org.apache.catalina.core.StandardServer await
SEVERE: StandardServer.await: create[8005]:
java.net.BindException: Cannot assign requested address
at java.net.PlainSocketImpl.socketBind(Native Method)
at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:365)
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:647)
at org.apache.catalina.startup.Catalina.start(Catalina.java:607)
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)
开始出现这错误,我的第一反应就是端口被占用,但经过反复查看端口并未被占用,日志中也可以看到 tomcat是已经启动了, 但不能绑定8005端口. 出现Cannot assign requested address,果断搜索了一番,查看很多都是因为端口被占用导致,但也有不是的,其中有一篇是说出现Cannot assign requested address的原因是localhost被路由到了别的机器.
在命令窗口
ping localhost
发现确实被路由到了别的机器.
这下就解决问题了,修改localhost让它重新指向本机地址 127.0.0.1vi /etc/hosts删除掉里面关于localhost的转向, 然后增加一行
127.0.0.1 localhost 重新启动tomcat, 问题都解决. |
|
|
|
|
|
|