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

  启动tomcat,错误信息如下:

严重: 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咋启动失败呢?难道tomcat也没有从假期调整过来?

  使用DOS命令netstat -an查看被占用的端口,并未发现有任何程序占用Tomcat使用的相关端口(例如8080),并且将Tomcat安装目录下的conf/server.xml文件中的端口改为其他端口,再次运行也无法正常启动。

  通过测试,可以初步判断应该不是端口占用引起的问题。

  如果不是端口占用的问题的话,那么就要考虑是否是IP绑定的问题了。

  查看hosts文件:C:\Windows\System32\drivers\etc\hosts


127.0.0.1       localhost
169.196.254.14    localhost

  把第二行ip去掉,再次启动,正常启动。

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

 原来公司电脑ip是动态分配的啊,原来曾经年前配置的ip,年后竟然失效,导致异常出现。

你可能感兴趣的:(Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突)