在linux下启动eclipse的tomcat程序出错,如下所示:
- 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: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:642 )
- at org.apache.catalina.startup.Catalina.start(Catalina.java:602 )
- 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 )
开始还以为是端口占用,在server.xml中将<Server port="8005" shutdown="SHUTDOWN">改为其他端口,出现同样的错误。
后来发现是因为localhost interface没有配置好的原因。
于是 ping localhost
直 接去ping一个远程地址了,打开/etc/hosts,发现127.0.0.1后面的主机名由localhost被改成了给该机器分配的主机名,改回 127.0.0.1 localhost.localdomain localhost,重启network后,启动tomcat,一切正常。
如果需要更改服务器的主机名和域名,需要修改/etc/sysconfig/network的HOSTNAME及DOMAINNAME,不能修改/etc/hosts中127.0.0.1对应的那条。