昨天启动 Tomcat 7.0 或者 Tomcat 8.0 时,壹直没法正确启动,不管是经过命令行调用批处理脚本仍是在 Eclipse 中集成以后再启动,所有都会提示以下异常堆栈信息:java
严重: StandardServer.await: create[8005]: java.net.BindException: Cannot assign requested address: 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.(ServerSocket.java:185) at org.apache.catalina.core.StandardServer.await(StandardServer.java:406) at org.apache.catalina.startup.Catalina.await(Catalina.java:676) at org.apache.catalina.startup.Catalina.start(Catalina.java:628) 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)
因为我机器上的 Tomcat 7.0 和 Tomcat 8.0 在此以前都是工做正常没有出过问题,因此能够确认安装包没有问题。apache
然而根据异常信息推测,多是 Tomcat 须要绑定的端口或某些资源被其余应用程序占用。在网上搜索了下,尝试 DOS 命令 netstat -an
查看被占用的端口,并未发现有任何程序占用 Tomcat 使用的相关端口(例如8080),而且将Tomcat安装目录下的 conf/server.xml
文件中的端口改成其余端口,再次运行也没法正常启动。服务器
经过多种测试,能够初步判断应该不是端口占用引发的问题。若是不是端口占用的问题的话,那么就要考虑是不是IP绑定的问题了。socket
通过检查,在文件 C:\Windows\System32\drivers\etc\hosts
中发现以下部份内容:测试
127.0.0.1 localhost 169.196.254.14 localhost
169.196.254.14 是一个不存在的本地IP地址,将hosts文件中的第二行内容 169.196.254.14 localhost
去掉后,再次启动Tomcat,发现运行正常!.net
在服务器领域,一台计算机配置多个IP地址是比较常见的。Tomcat在启动时,会根据配置去获取全部的IP地址,而且进行逐个绑定,当发现须要绑定的IP地址不存在时,将会触发上述异常,从而致使没法正常启动。命令行
若是想知道某台机器上的 localhost 绑定了哪几個 IP 地址,可使用以下 Java 代码来简单的输出结果。code
//输出 localhost 映射的全部IP地址 InetAddress[] ips = InetAddress.getAllByName("localhost"); if (ips != null) { for (InetAddress ip : ips) { System.out.println(ip.getHostAddress()); } }
把 127.0.0.1 localhost 之外的其它映射删除以后,再重启 Tomcat ,问题解决。server