欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突

程序员文章站 2024-03-08 18:04:40
前言: 最近朋友遇到在安装并启动tomcat 6.0时,发现一直无法正确启动,主要异常堆栈信息如下: 严重: standardserver.await: cre...

前言:

最近朋友遇到在安装并启动tomcat 6.0时,发现一直无法正确启动,主要异常堆栈信息如下:

严重: 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 6.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地址
inetaddress[] ips = inetaddress.getallbyname("localhost");
if (ips != null) {
  for (inetaddress ip : ips) {
    system.out.println(ip.gethostaddress());
  }
}
/* 修改上述hosts文件前,输出:
* 169.196.254.14
* 127.0.0.1
* 修改文件后,输出
* 127.0.0.1
*/

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!