Java Tomcat运行在8080端口,但是无法使用IP地址远程访问?
声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow
原文地址: http://stackoverflow.com/questions/32266553/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me):
StackOverFlow
Tomcat is running on port 8080, but unable to access remotely using IP address?
提问by Sushant Srivastava
I have freshly installed apache-tomcat-7.0.62 on my server. When i start tomcat it start with no errors, but when i want to access it using browser it says page is unavailable. I have used following command to check whether tomcat is running correctly or not :-
我在我的服务器上新安装了 apache-tomcat-7.0.62。当我启动 tomcat 时,它开始时没有错误,但是当我想使用浏览器访问它时,它说页面不可用。我使用以下命令来检查 tomcat 是否正常运行:-
netstat -ntlp | grep LISTEN
and following is the output : -
以下是输出: -
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
tcp 0 0 127.0.0.1:8005 0.0.0.0:* LISTEN 19430/java
tcp 0 0 0.0.0.0:8009 0.0.0.0:* LISTEN 19430/java
tcp 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:8080 0.0.0.0:* LISTEN 19430/java
tcp6 0 0 :::22 :::* LISTEN -
tcp6 0 0 :::8000 :::* LISTEN -
tcp6 0 0 :::80 :::* LISTEN -
TCP 0 0 0.0.0.0:22 0.0.0.0:* LISTEN -
TCP 0 0 127.0.0.1:8005 0.0.0.0:* LISTEN 19430 / JAVA
TCP 0 0 0.0.0.0:8009 0.0.0.0:* LISTEN 19430 / JAVA
TCP 0 0 127.0.0.1:3306 0.0.0.0:* LISTEN -
tcp 0 0 0.0.0.0:8080 0.0.0.0:* LISTEN 19430/java
tcp6 0 0 :::22 :::*
6:0 t 8000 :::*
听- tcp6 0 0 :::80 :::* 听-
following is the contents of catalina.out
以下是catalina.out的内容
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server version: Apache Tomcat/7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server built: May 7 2015 17:14:55 UTC
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Server number: 7.0.62.0
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: OS Name: Linux
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: OS Version: 3.13.0-48-generic
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Architecture: amd64
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Java Home: /usr/lib/jvm/java-7-openjdk-amd64/jre
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: JVM Version: 1.7.0_79-b14
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: JVM Vendor: Oracle Corporation
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: CATALINA_BASE: /home/ubuntu/apache-tomcat-7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: CATALINA_HOME: /home/ubuntu/apache-tomcat-7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: - Djava.util.logging.config.file=/home/ubuntu/apache-tomcat- 7.0.62/conf/logging.properties
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: - Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Djava.net.preferIPv4Stack=true
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Djava.net.preferIPv4Addresses=true
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Djava.endorsed.dirs=/home/ubuntu/apache- tomcat-7.0.62/endorsed
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dcatalina.base=/home/ubuntu/apache- tomcat-7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Dcatalina.home=/home/ubuntu/apache- tomcat-7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.VersionLoggerListener log
INFO: Command line argument: -Djava.io.tmpdir=/home/ubuntu/apache- tomcat-7.0.62/temp
Aug 28, 2015 7:56:39 AM org.apache.catalina.core.AprLifecycleListener lifecycleEvent
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: /usr/java/packages/lib/amd64:/usr/lib/x86_64-linux- gnu/jni:/lib/x86_64-linux-gnu:/usr/lib/x86_64-linux- gnu:/usr/lib/jni:/lib:/usr/lib
Aug 28, 2015 7:56:39 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["http-bio-8080"]
Aug 28, 2015 7:56:39 AM org.apache.coyote.AbstractProtocol init
INFO: Initializing ProtocolHandler ["ajp-bio-8009"]
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 1060 ms
Aug 28, 2015 7:56:39 AM org.apache.catalina.core.StandardService startInternal
INFO: Starting service Catalina
Aug 28, 2015 7:56:39 AM org.apache.catalina.core.StandardEngine startInternal
INFO: Starting Servlet Engine: Apache Tomcat/7.0.62
Aug 28, 2015 7:56:39 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /home/ubuntu/apache-tomcat- 7.0.62/webapps/ROOT
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory /home/ubuntu/apache - tomcat-7.0.62/webapps/ROOT has finished in 805 ms
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /home/ubuntu/apache-tomcat- 7.0.62/webapps/examples
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory /home/ubuntu/apache- tomcat-7.0.62/webapps/examples has finished in 611 ms
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /home/ubuntu/apache-tomcat- 7.0.62/webapps/host-manager
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory /home/ubuntu/apache- tomcat-7.0.62/webapps/host-manager has finished in 204 ms
Aug 28, 2015 7:56:40 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /home/ubuntu/apache-tomcat -7.0.62/webapps/manager
Aug 28, 2015 7:56:41 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory /home/ubuntu/apache- tomcat-7.0.62/webapps/manager has finished in 107 ms
Aug 28, 2015 7:56:41 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deploying web application directory /home/ubuntu/apache-tomcat- 7.0.62/webapps/docs
Aug 28, 2015 7:56:41 AM org.apache.catalina.startup.HostConfig deployDirectory
INFO: Deployment of web application directory /home/ubuntu/apache- tomcat-7.0.62/webapps/docs has finished in 115 ms
Aug 28, 2015 7:56:41 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["http-bio-8080"]
Aug 28, 2015 7:56:41 AM org.apache.coyote.AbstractProtocol start
INFO: Starting ProtocolHandler ["ajp-bio-8009"]
Aug 28, 2015 7:56:41 AM org.apache.catalina.startup.Catalina start
INFO: Server startup in 1960 ms
Following is the content of server.xmlfile
以下是server.xml文件的内容
<?xml version='1.0' encoding='utf-8'?>
<!--
Licensed to the Apache Software Foundation (ASF) under one or more
contributor license agreements. See the NOTICE file distributed with
this work for additional information regarding copyright ownership.
The ASF licenses this file to You under the Apache License, Version 2.0
(the "License"); you may not use this file except in compliance with
the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
-->
<!-- Note: A "Server" is not itself a "Container", so you may not
define subcomponents such as "Valves" at this level.
Documentation at /docs/config/server.html
-->
<Server port="8005" shutdown="SHUTDOWN">
<Listener className="org.apache.catalina.startup.VersionLoggerListener" />
<!-- Security listener. Documentation at /docs/config/listeners.html
<Listener className="org.apache.catalina.security.SecurityListener" />
-->
<!--APR library loader. Documentation at /docs/apr.html -->
<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
<!--Initialize Jasper prior to webapps are loaded. Documentation at /docs/jasper-howto.html -->
<Listener className="org.apache.catalina.core.JasperListener" />
<!-- Prevent memory leaks due to use of particular java/javax APIs-->
<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
<Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
<!-- Global JNDI resources
Documentation at /docs/jndi-resources-howto.html
-->
<GlobalNamingResources>
<!-- Editable user database that can also be used by
UserDatabaseRealm to authenticate users
-->
<Resource name="UserDatabase" auth="Container"
type="org.apache.catalina.UserDatabase"
description="User database that can be updated and saved"
factory="org.apache.catalina.users.MemoryUserDatabaseFactory"
pathname="conf/tomcat-users.xml" />
</GlobalNamingResources>
<!-- A "Service" is a collection of one or more "Connectors" that share
a single "Container" Note: A "Service" is not itself a "Container",
so you may not define subcomponents such as "Valves" at this level.
Documentation at /docs/config/service.html
-->
<Service name="Catalina">
<!--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="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
useIPVHosts="true" />
<!-- A "Connector" using the shared thread pool-->
<!--
<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
-->
<!-- Define a SSL HTTP/1.1 Connector on port 8443
This connector uses the BIO implementation that requires the JSSE
style configuration. When using the APR/native implementation, the
OpenSSL style configuration is required as described in the APR/native
documentation -->
<!--
<Connector port="8443" protocol="org.apache.coyote.http11.Http11Protocol"
maxThreads="150" SSLEnabled="true" 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>
<Host name="mining.knowaptitude.in" appBase="mining_apps"
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>
</Service>
</Server>
采纳答案by Azhar
Please check if port 8080 is accessible from outside. port could be blocked. Check your firewall settings and open the port for http request.
请检查是否可以从外部访问端口 8080。端口可能被阻塞。检查您的防火墙设置并打开 http 请求的端口。
回答by thienkhoi tran
You have to setting NAT for your router to connect from the internet.
You don't need to do that if you connect from lan.
I checked and your port is closing.
Use this tool to check http://www.yougetsignal.com/tools/open-ports/
Or http://www.canyouseeme.org/
您必须为路由器设置 NAT 才能从 Internet 连接。
如果您从局域网连接,则不需要这样做。
我查了一下,你的端口正在关闭。
使用此工具检查http://www.yougetsignal.com/tools/open-ports/
或http://www.canyouseeme.org/
回答by Steven
disable firewalld:
# systemctl stop firewalld # systemctl disable firewalld
replace localhost with a valid IP that can be exposed externally in server.xml
禁用防火墙:
# systemctl stop firewalld # systemctl disable firewalld
用可以在 server.xml 中对外公开的有效 IP 替换 localhost