Apache TomCat funktioniert nur auf localhost – Windows 2012

Apache TomCat funktioniert nur auf localhost – Windows 2012

Ich habe Apache Tomcat auf Windows Server 2012 installiert und kann lokal darauf zugreifen

Bisher habe ich Folgendes versucht: – Port über die Firewall geöffnet. – Port über meinen Cloud-Server-Host geöffnet. – Windows-Firewall ausgeschaltet. – Änderungen an der Datei server.xml vorgenommen. – meinen Cloud-Server-Host kontaktiert, der bestätigt hat, dass Port 90 funktioniert. – Mein Hosting-Provider hat es versucht, aber auch dort hat es nicht geklappt.

Ich habe den Dienst gestoppt und neu gestartet und nichts hat funktioniert:

Unten ist meine server.xml-Datei. Die Protokolle scheinen keine Fehler zu enthalten, wenn ich versuche, darauf zuzugreifen.

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

Sofern nicht durch geltendes Recht vorgeschrieben oder schriftlich vereinbart, wird die unter der Lizenz vertriebene Software „WIE BESEHEN“ vertrieben, OHNE GARANTIEN ODER BEDINGUNGEN JEGLICHER ART, weder ausdrücklich noch stillschweigend. Die spezifischen Bestimmungen zu den Berechtigungen und Beschränkungen unter der Lizenz finden Sie in der Lizenz. --> -->

<!--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>

Ich bin bitte um jede Hilfe, denn im Moment drehe ich mich scheinbar im Kreis.

Vielen Dank im Voraus, John

Antwort1

Bei mir hat das unter Linux funktioniert. Sie können diesen Fix unter Windows ausprobieren, um remote auf Tomcat zuzugreifen.

Öffnen Sie die folgenden beiden XML-Dateien in einem Texteditor und kommentieren Sie die folgenden Zeilen aus:

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

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

Auskommentieren:

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

Starten Sie Ihren Tomcat-Server neu und prüfen Sie, ob diese Lösung hilft.

Antwort2

Nach vielen Stunden stellte sich heraus, dass mein Hosting-Unternehmen nicht den richtigen Firewall-Port geöffnet hatte, z. B. 80 statt 8080.

Leasson hat gelernt, dass man immer auf sein Bauchgefühl hören sollte. Ich habe sie vor der Platzierung hier gefragt, ob es geöffnet sei, aber das war nicht der Fall.

Wie dem auch sei, jeder, der diesbezüglich hierher kommt, sollte dreimal überprüfen, ob die Ports seiner Firewall geöffnet sind.

Hoffe, es hilft jemand anderem weiter.

Danke, John

verwandte Informationen