Tomcat Cannot assign requested address: JVM_Bind

浪子不回头ぞ 提交于 2019-12-05 08:37:44

昨天启动 Tomcat 7.0 或者 Tomcat 8.0 时,壹直无法正确启动,无论是通过命令行调用批处理脚本还是在 Eclipse 中集成之后再启动,全部都会提示如下异常堆栈信息:

严重: 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 在此之前都是工作正常没有出过问题,所以可以确认安装包没有问题。

然而根据异常信息推测,可能是 Tomcat 需要绑定的端口或某些资源被其他应用程序占用。在网上搜索了下,尝试 DOS 命令 netstat -an 查看被占用的端口,并未发现有任何程序占用 Tomcat 使用的相关端口(例如8080),并且将Tomcat安装目录下的 conf/server.xml 文件中的端口改为其他端口,再次运行也无法正常启动。

通过多种测试,可以初步判断应该不是端口占用引起的问题。如果不是端口占用的问题的话,那么就要考虑是否是IP绑定的问题了。

经过检查,在文件 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,发现运行正常!

在服务器领域,一台计算机配置多个IP地址是比较常见的。Tomcat在启动时,会根据配置去获取所有的IP地址,并且进行逐个绑定,当发现需要绑定的IP地址不存在时,将会触发上述异常,从而导致无法正常启动。

如果想知道某台机器上的 localhost 绑定了哪几個 IP 地址,可以使用如下 Java 代码来简单的输出结果。

//输出 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 ,问题解决。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!