gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

前言:

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
严重: 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文件中发现如下部分内容:

?
1
2
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地址不存在时,将会触发上述异常,从而导致无法正常启动.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
//输出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
*/

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

最后此篇关于Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突的文章就讲到这里了,如果你想了解更多关于Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com