【问题标题】:Tomcat Problem :java.net.BindException: Address already in use <null>:8080 at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:549)Tomcat 问题:java.net.BindException:地址已在使用中 <null>:8080 at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:549)
【发布时间】:2011-07-16 08:09:07
【问题描述】:

我使用 tomcat 作为我的网络服务器。我有应用程序需要在用户单击编辑按钮后重新启动 tomcat 服务器。为此,我在控制器上编写了如下代码:

if (updateResult ==1) 
{
   //String command = "/home/sunil_shiwankar/Tempo/apache-tomcat-6.0.32/startup.sh";//for linux use .sh
    String command = this.getClass().getResource("/").getPath();
    System.out.println("{{{{{{{{{{{{{{{{{{{{{{{{{{{"+ command);
    command = command.replace(command.substring(command.lastIndexOf("webapps"), command.length()), "");
    System.out.println("{{{{{{{{{{{{{{{{{{{{{{{{{{{ AFTER MODIFYING COMMAND IS "+ command);
    try
    {
      String shutDownCommand = command+"bin/shutdown.sh";
      Process child = Runtime.getRuntime().exec(shutDownCommand);
      System.out.println("{{{{{{{{{{{{{{{{{{{{{{{{{{{ SHUTDOWN TOMCAT SUCCESSFULLY }}}}}}}}}}}}}}");
    } catch (Exception e) 
    {
        String inExceptionStartCommand = command+"bin/startup.sh";
        Process child = Runtime.getRuntime().exec(inExceptionStartCommand);
        System.out.println("{{{{{{{{{{{{{{{{{{{{{{{{{{{ TOMCAT STARTED WITH EXCEPTION SUCCESSFULLY }}}}}}}}}}}}}}");
        e.printStackTrace();
    }
        String normalStartCommand = command+"bin/startup.sh"; 
        Process child = Runtime.getRuntime().exec(normalStartCommand);
        System.out.println("{{{{{{{{{{{{{{{{{{{{{{{{{{{ TOMCAT STARTED WITOUT EXCEPTION SUCCESSFULLY }}}}}}}}}}}}}}");
}

我的 tomcat 版本 6.0.32 并且在运行我的应用程序时它会关闭 tomcat 服务器并以异常启动

java.net.BindException: Address already in use <null>:8080
    at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:549)
    at org.apache.coyote.http11.Http11Protocol.init(Http11Protocol.java:176)
    at org.apache.catalina.connector.Connector.initialize(Connector.java:1022)
    at org.apache.catalina.core.StandardService.initialize(StandardService.java:703)
    at org.apache.catalina.core.StandardServer.initialize(StandardServer.java:838)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:538)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:562)
    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.load(Bootstrap.java:261)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)
Caused by: java.net.BindException: Address already in use
    at java.net.PlainSocketImpl.socketBind(Native Method)
    at java.net.PlainSocketImpl.bind(PlainSocketImpl.java:365)
    at java.net.ServerSocket.bind(ServerSocket.java:319)
    at java.net.ServerSocket.<init>(ServerSocket.java:185)
    at java.net.ServerSocket.<init>(ServerSocket.java:141)
    at org.apache.tomcat.util.net.DefaultServerSocketFactory.createSocket(DefaultServerSocketFactory.java:50)
    at org.apache.tomcat.util.net.JIoEndpoint.init(JIoEndpoint.java:538)
    ... 12 more
16 Mar, 2011 10:17:43 AM org.apache.catalina.core.StandardService initialize
SEVERE: Failed to initialize connector [Connector[HTTP/1.1-8080]]
LifecycleException:  Protocol handler initialization failed: java.net.BindException: Address already in use <null>:8080
    at org.apache.catalina.connector.Connector.initialize(Connector.java:1024)
    at org.apache.catalina.core.StandardService.initialize(StandardService.java:703)
    at org.apache.catalina.core.StandardServer.initialize(StandardServer.java:838)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:538)
    at org.apache.catalina.startup.Catalina.load(Catalina.java:562)
    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.load(Bootstrap.java:261)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

请帮我解决

提前致谢

【问题讨论】:

标签: java tomcat


【解决方案1】:

我也遇到了这个问题,就我而言,在尝试配置 Tomcat 时,我创建了 2 个“引擎”。我在 ./conf/server.xml 中有这样一行:

&lt;Engine name="Catalina" defaultHost="localhost"&gt;

我更改了此设置以匹配早期 server.xml 中的设置:

&lt;Engine name="Standalone" defaultHost="localhost"&gt;

我没有意识到这会在 ./conf/Catalina/ 和 ./conf/Standalone/ 中创建两个独立的配置。这两个冲突并给了我与这篇文章相同的错误。

我关闭了 tomcat,删除了 ./conf/Catalina/ 和 ./conf/Standalone 子目录,然后重新启动。 Tomcat 创建了新的,不再有冲突!

【讨论】:

    【解决方案2】:

    我在端口 8080 上遇到了同样的 BindException 问题。我按照以下步骤操作:

    netstat -tulpn
    

    它列出了所有进程 ID 和它们正在侦听的端口。然后我在列表中搜索端口 8080,然后查找它的 PID。 PID 是 1654。然后我使用以下命令终止了该进程:

    kill -9 1654
    

    然后我启动了 tomcat 服务器,它运行良好。希望能帮助到你! :)

    【讨论】:

      【解决方案3】:

      该代码虽然难以阅读,但似乎并未等待关闭发生。我怀疑当您尝试重新启动它时它仍在关闭过程中。当然,异常表明它仍在运行,因为它的 http 端口仍在使用中。要暂时跟踪问题,请尝试在关机和启动之间休眠,看看是否能解决问题。

      【讨论】:

      • 我尝试过 1000 毫秒的睡眠,但异常是一样的
      • 尝试 10 或 100 次。在服务器关闭之前,一些 servlet 可能需要做大量的工作(例如,完成“飞行中”的请求并将状态刷新到磁盘)。
      • 感谢斯蒂芬和梅尔夫的帮助。你的帮助对我有用。
      【解决方案4】:

      其他一些应用程序已经在侦听端口 8080。终止该进程,然后运行您的服务器。一次只能有一个进程附加到一个进程。查找已经绑定到该端口的进程是特定于操作系统的。

      【讨论】:

      • 但正如我在用户操作上所说的那样,我如何在运行时终止进程。首先,当我运行我的应用程序时,服务器在端口 8080 上启动。但是在用户编辑操作中,我重新启动了我的服务器,然后这个异常来了,在这之间我可以如何杀死进程。有定时器任务在后台运行定时器任务有任何问题
      • 定时器任务是一个守护线程,它不应该阻止 JVM 关闭。如果不是……那么您的 servlet 需要侦听相关的生命周期事件并以适当的方式终止计时器任务。
      猜你喜欢
      • 1970-01-01
      • 2012-04-14
      • 1970-01-01
      • 1970-01-01
      • 2014-11-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多