![Apache TomCat funktioniert nur auf localhost – Windows 2012](https://rvso.com/image/697018/Apache%20TomCat%20funktioniert%20nur%20auf%20localhost%20%E2%80%93%20Windows%202012.png)
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 "%r" %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