Apache TomCat работает только на локальном хосте - Windows 2012

Apache TomCat работает только на локальном хосте - Windows 2012

Я установил Apache Tomcat на Windows Server 2012 и могу получить к нему локальный доступ.

На данный момент я попробовал следующее: - открыл порт через брандмауэр; - открыл порт через хост моего облачного сервера; - отключил брандмауэр Windows; - внес изменения в файл server.xml; - связался с хостом моего облачного сервера, который подтвердил, что порт 90 работает; - мой хостинг-провайдер попытался сделать это, но ему тоже не удалось заставить его работать.

Я останавливал и перезапускал службу, но ничего не помогло:

Ниже представлен мой файл server.xml. Журналы, похоже, не содержат никаких ошибок при попытке доступа к нему.

  http://www.apache.org/licenses/LICENSE-2.0

Если применимое законодательство не требует иного или не согласовано в письменной форме, программное обеспечение, распространяемое по Лицензии, распространяется на условиях «КАК ЕСТЬ», БЕЗ КАКИХ-ЛИБО ГАРАНТИЙ ИЛИ УСЛОВИЙ, как явных, так и подразумеваемых. Конкретный язык, регулирующий разрешения и ограничения по Лицензии, см. в Лицензии. --> -->

<!--The connectors can use a shared executor, you can define one or more named thread pools-->
<!--
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
    maxThreads="150" minSpareThreads="4"/>
-->


<!-- A "Connector" represents an endpoint by which requests are received
     and responses are returned. Documentation at :
     Java HTTP Connector: /docs/config/http.html (blocking & non-blocking)
     Java AJP  Connector: /docs/config/ajp.html
     APR (HTTP/AJP) Connector: /docs/apr.html
     Define a non-SSL HTTP/1.1 Connector on port 8080
-->
<Connector port="9090" protocol="HTTP/1.1"
           connectionTimeout="20000"
           redirectPort="8443"
     address="0.0.0.0" />
<!-- A "Connector" using the shared thread pool-->
<!--
<Connector executor="tomcatThreadPool"
           port="9090" protocol="HTTP/1.1"
           connectionTimeout="20000"
           redirectPort="8443"
    address="0.0.0.0" />
-->
<!-- Define a SSL HTTP/1.1 Connector on port 8443
     This connector uses the JSSE configuration, when using APR, the
     connector should be using the OpenSSL style configuration
     described in the APR documentation -->
<!--
<Connector port="8443" protocol="HTTP/1.1" SSLEnabled="true"
           maxThreads="150" scheme="https" secure="true"
           clientAuth="false" sslProtocol="TLS" />
-->

<!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />


<!-- An Engine represents the entry point (within Catalina) that processes
     every request.  The Engine implementation for Tomcat stand alone
     analyzes the HTTP headers included with the request, and passes them
     on to the appropriate Host (virtual host).
     Documentation at /docs/config/engine.html -->

<!-- You should set jvmRoute to support load-balancing via AJP ie :
<Engine name="Catalina" defaultHost="localhost" jvmRoute="jvm1">
-->
<Engine name="Catalina" defaultHost="localhost">

  <!--For clustering, please take a look at documentation at:
      /docs/cluster-howto.html  (simple how to)
      /docs/config/cluster.html (reference documentation) -->
  <!--
  <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
  -->

  <!-- Use the LockOutRealm to prevent attempts to guess user passwords
       via a brute-force attack -->
  <Realm className="org.apache.catalina.realm.LockOutRealm">
    <!-- This Realm uses the UserDatabase configured in the global JNDI
         resources under the key "UserDatabase".  Any edits
         that are performed against this UserDatabase are immediately
         available for use by the Realm.  -->
    <Realm className="org.apache.catalina.realm.UserDatabaseRealm"
           resourceName="UserDatabase"/>
  </Realm>

  <Host name="localhost"  appBase="webapps"
        unpackWARs="true" autoDeploy="true">

    <!-- SingleSignOn valve, share authentication between web applications
         Documentation at: /docs/config/valve.html -->
    <!--
    <Valve className="org.apache.catalina.authenticator.SingleSignOn" />
    -->

    <!-- Access log processes all example.
         Documentation at: /docs/config/valve.html
         Note: The pattern used is equivalent to using pattern="common" -->
    <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
           prefix="localhost_access_log." suffix=".txt"
           pattern="%h %l %u %t &quot;%r&quot; %s %b" />

  </Host>
</Engine>

Помогите, пожалуйста, а то я сейчас, кажется, хожу по кругу.

Спасибо заранее, Джон.

решение1

Это сработало для меня в Linux. Вы можете попробовать это исправление в Windows, чтобы получить удаленный доступ к Tomcat.

Откройте следующие два XML-файла в текстовом редакторе и закомментируйте следующие строки:

1) $CATALINA_HOME/webapps/manager/META-INF/context.xml

2) $CATALINA_HOME/webapps/host-manager/META-INF/context.xml

Закомментировать:

<!--  <Valve className="org.apache.catalina.valves.RemoteAddrValve"
      allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />-->

Перезапустите сервер Tomcat и посмотрите, поможет ли это решение.

решение2

Спустя много часов выяснилось, что моя хостинговая компания не открыла правильный порт брандмауэра, например, они открыли 80 вместо 8080.

Урок, который я извлек, всегда следуйте своим внутренним ощущениям. Я спросил их, прежде чем разместить здесь, открыто ли это, но это было не так.

В любом случае, если кто-то заходит сюда по этому поводу, пожалуйста, трижды проверьте, открыты ли порты вашего брандмауэра.

Надеюсь, это поможет кому-то ещё.

Спасибо, Джон.

Связанный контент