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

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-08-11 12:14:50  来源:igfitidea点击:

Tomcat is running on port 8080, but unable to access remotely using IP address?

javatomcatubuntutcp

提问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 &quot;%r&quot; %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 &quot;%r&quot; %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

  1. disable firewalld:

    # systemctl stop firewalld
    # systemctl disable firewalld
    
  2. replace localhost with a valid IP that can be exposed externally in server.xml

  1. 禁用防火墙:

    # systemctl stop firewalld
    # systemctl disable firewalld
    
  2. 用可以在 server.xml 中对外公开的有效 IP 替换 localhost