Проблема Tomcat: java.net.BindException: адрес уже используется <null>: 8080 в org.apache.tomcat.util.net.JIoEndpoint.init (JIoEndpoint.java:549) - PullRequest
2 голосов
/ 16 марта 2011

Я использую 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)

Пожалуйста, помогите мне решить

Спасибо заранее

Ответы [ 4 ]

4 голосов
/ 16 марта 2011

Этот код, хотя его трудно прочитать, похоже, не ожидает завершения работы. Я подозреваю, что он все еще находится в процессе выключения, когда вы пытаетесь запустить его снова. Конечно, исключение указывает, что он все еще работает, потому что его http-порт все еще используется. Чтобы временно отследить проблему, попробуйте установить режим сна между выключением и запуском, чтобы убедиться, что проблема устранена.

2 голосов
/ 16 марта 2011

Некоторые другие приложения уже прослушивают порт 8080. Завершите этот процесс и запустите сервер.Только один процесс может присоединиться к процессу одновременно.Поиск процесса, который уже связан с этим портом, зависит от конкретной ОС.

0 голосов
/ 22 февраля 2017

У меня тоже была эта проблема, и в моем случае при попытке настроить Tomcat я создал 2 «движка». У меня была такая строка в ./conf/server.xml:

<Engine name="Catalina" defaultHost="localhost">

Я изменил этот параметр, чтобы он соответствовал параметру в более раннем файле server.xml:

<Engine name="Standalone" defaultHost="localhost">

Что я не осознавал, так это то, что это создало две отдельные конфигурации в ./conf/Catalina/ и ./conf/Standalone/. Эти два противоречили друг другу и дали мне ту же ошибку, что и в этом посте.

Я выключил tomcat, удалил оба подкаталога ./conf/Catalina/ и ./conf/Standalone и перезапустил. Tomcat создал новый, и больше никаких конфликтов!

0 голосов
/ 22 сентября 2014

Я столкнулся с той же проблемой BindException на порту 8080. Я выполнил следующие действия:

netstat -tulpn

В нем перечислены все идентификаторы процессов и порты, которые они прослушивали. Затем я искал порт 8080 в списке, а затем искал его PID. PID был 1654. Затем я убил процесс, используя следующую команду:

kill -9 1654

Затем я запустил сервер Tomcat, и он работал нормально. Надеюсь, поможет! :)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...