zoukankan      html  css  js  c++  java
  • tomcat学习


    参考视频:Tomcat下载安装配置使用视频教程

    前言

    tomcat的下载安装配置等简单操作就不在此多说了,本文看看tomcat的核心。

    一、tomcat解读server.xml文件

    tomcat的核心server.xml文件在conf目录下:
    在这里插入图片描述
    打开server.xml后,其中有一段名为Catalina的Service代码:

      <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
             Java AJP  Connector: /docs/config/ajp.html
             APR (HTTP/AJP) Connector: /docs/apr.html
             Define a non-SSL/TLS HTTP/1.1 Connector on port 8080
        -->
        <Connector URIEncoding="gbk" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
        <!-- A "Connector" using the shared thread pool-->
        <!--
        <Connector executor="tomcatThreadPool"
                   port="8080" protocol="HTTP/1.1"
                   connectionTimeout="20000"
                   redirectPort="8443" />
        -->
        <!-- Define a SSL/TLS HTTP/1.1 Connector on port 8443
             This connector uses the NIO implementation. The default
             SSLImplementation will depend on the presence of the APR/native
             library and the useOpenSSL attribute of the
             AprLifecycleListener.
             Either JSSE or OpenSSL style configuration may be used regardless of
             the SSLImplementation selected. JSSE style configuration is used below.
        -->
        <!--
        <Connector port="8443" protocol="org.apache.coyote.http11.Http11NioProtocol"
                   maxThreads="150" SSLEnabled="true">
            <SSLHostConfig>
                <Certificate certificateKeystoreFile="conf/localhost-rsa.jks"
                             type="RSA" />
            </SSLHostConfig>
        </Connector>
        -->
        <!-- Define a SSL/TLS HTTP/1.1 Connector on port 8443 with HTTP/2
             This connector uses the APR/native implementation which always uses
             OpenSSL for TLS.
             Either JSSE or OpenSSL style configuration may be used. OpenSSL style
             configuration is used below.
        -->
        <!--
        <Connector port="8443" protocol="org.apache.coyote.http11.Http11AprProtocol"
                   maxThreads="150" SSLEnabled="true" >
            <UpgradeProtocol className="org.apache.coyote.http2.Http2Protocol" />
            <SSLHostConfig>
                <Certificate certificateKeyFile="conf/localhost-rsa-key.pem"
                             certificateFile="conf/localhost-rsa-cert.pem"
                             certificateChainFile="conf/localhost-rsa-chain.pem"
                             type="RSA" />
            </SSLHostConfig>
        </Connector>
        -->
    
        <!-- 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 defaultHost="localhost" name="Catalina">
    
          <!--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 appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="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" pattern="%h %l %u %t &quot;%r&quot; %s %b" prefix="localhost_access_log" suffix=".txt"/>
    
          <Context docBase="E:apache-tomcat-8.5.28wtpwebappsChineseWeb" path="/ChineseWeb" reloadable="true" source="org.eclipse.jst.jee.server:ChineseWeb"/></Host>
        </Engine>
      </Service>
    

    浏览器如果想使用Service这个服务,就必须通过连接器Connector,使用http/1.1协议,访问port:8080端口,这也就是为什么我们要在浏览器输入http://localhost:8080的原因:

        <Connector URIEncoding="gbk" connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
    

    接下来我们看看Host标签(主机),appBase规定了我们的应用app要放在webapps目录下,unpackWARs=ture表示项目的war包放在webapps目录下后会自动解压,autoDeploy="true"表示发布项目时不用重启服务器

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

    tomcat核心原理图:在这里插入图片描述

    二、虚拟主机

    我们有时会租赁百度云或者阿里云的服务器,获得域名。服务端不可能让我们一个域名占用一台机器,通常一台机器负责多个域名,这些域名就是虚拟主机。

    一个Engine可以包含多个虚拟主机,一个主机可以包含多个应用Context。

    1. 创建虚拟目录:

    我们的app都放在webapps下,可不可以放在其他地方呢?当然可以,

    第一种方法(在主机下创建一个新的Context):
    比如我在tomcat根目录下创建一个web应用 myWeb
    在这里插入图片描述
    然后修改server.xml文件,在Host标签下添加一个访问路径为/myWeb(可以写别的),的Context标签(相当于在主机下添加一个应用),部分代码如下:

    <Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">
    		<Context path="/myWeb" docBase="e:/apache-tomcat-8.5.28/myWeb"/>
    

    然后重启服务器(重新加载server.xml),然后输入http://localhost:8080/myWeb就可以访问到。

    此方法相当于创建了一个myWeb的虚拟目录,但有弊端,因为要重启服务器,有时服务器上不知跑你一个程序,你重启后势必影响其他应用。

    第二种方法(创建虚拟目录,推荐):
    在conf/Catalina/下有个localhost文件夹,在这里创建一个myWeb.xml文件,内容如下:
    在这里插入图片描述

    <?xml version="1.0"?>
    <Context docBase="e:/apache-tomcat-8.5.28/myWeb" />
    

    此时不必要重启服务器,服务器会自动加载myWeb.xml。
    然后访问http://localhost:8080/myWeb就行


    2. 创建虚拟主机:

    首先了解一些概念:
    域名:每个域名(好记)对应了一个ip地址(不好记),以百度(www.baidu.com)为例:

    C:UsersAdministrator>ping www.baidu.com
    
    Pinging www.a.shifen.com [14.215.177.39] with 32 bytes of data:
    Reply from 14.215.177.39: bytes=32 time=25ms TTL=50
    Reply from 14.215.177.39: bytes=32 time=24ms TTL=50
    Reply from 14.215.177.39: bytes=32 time=53ms TTL=50
    Reply from 14.215.177.39: bytes=32 time=37ms TTL=50
    
    Ping statistics for 14.215.177.39:
        Packets: Sent = 4, Received = 4, Lost = 0 (0% loss),
    Approximate round trip times in milli-seconds:
        Minimum = 24ms, Maximum = 53ms, Average = 34ms
    

    所以现在百度域名对应的ip地址为 14.215.177.39

    域名服解析服务(DNS):为域名和ip地址提供映射的服务器成为DNS服务器

    =============== 现在开始创建虚拟主机========================

    创建虚拟主机:在server.xml文件中host标签同级的地方再创建一个host,修改name,然后把appBase指向另一个目录(要区别于localhost的webapps)

    <Host name="www.xsy.com" appBase="webapps2" autoDeploy="true" unpackWARs="true"></Host>
    

    然后将webapps下tomcat自带的ROOT项目复制到webapps2下,作为虚拟主机www.xsy.com的项目,然后点击tomcat下bin/startup.bat,启动服务器。可以看到conf/Catalina下多出来了一个文件夹www.xsy.com(虚拟主机)
    在这里插入图片描述
    现在还访问不了,因为DNS没有配置好,我们接下来打开本地DNS服务:

    C:WindowsSystem32driversetchost

    修改文件如下(加上127.0.0.1 www.xsy.com):

    # Copyright (c) 1993-2009 Microsoft Corp.
    #
    # This is a sample HOSTS file used by Microsoft TCP/IP for Windows.
    #
    # This file contains the mappings of IP addresses to host names. Each
    # entry should be kept on an individual line. The IP address should
    # be placed in the first column followed by the corresponding host name.
    # The IP address and the host name should be separated by at least one
    # space.
    #
    # Additionally, comments (such as these) may be inserted on individual
    # lines or following the machine name denoted by a '#' symbol.
    #
    # For example:
    #
    #      102.54.94.97     rhino.acme.com          # source server
    #       38.25.63.10     x.acme.com              # x client host
    
    # localhost name resolution is handled within DNS itself.
    #	127.0.0.1       localhost
    #	::1             localhost
    	127.0.0.1		www.xsy.com
    

    然后无需重新启动服务器,直接在网站里输入:www.xsy.com:8080,就可以访问到我们虚拟主机下的ROOT项目的主页了
    在这里插入图片描述

    注意!当访问127.0.0.1:8080时,访问的说localhost下的项目,因为在server.xml中有这样一句代码(127.0.0.1默认访问localhost下的项目):

    <Engine defaultHost="localhost" name="Catalina">
    

    我们如何去掉www.xsy.com:8080后面的端口号呢?只需要将server.xml关于8080的代码的port修改为80就可以了:

    <Connector URIEncoding="gbk" connectionTimeout="20000" port="80" protocol="HTTP/1.1" redirectPort="8443"/>
    

    这时输入www.xsy.com就可以直接访问了
    在这里插入图片描述

  • 相关阅读:
    rsync备份服务
    Linux命令行基础及基础命令
    Linux重要目录及文件
    shell编程基础
    学习与生活
    从0开始使用python flask编写博客网站(2)
    python 七牛云图床的使用
    从0开始使用python flask编写博客网站(1)
    如何学习编程 我的编程学习之路
    Pyqt5 基本布局方式
  • 原文地址:https://www.cnblogs.com/theory/p/11884311.html
Copyright © 2011-2022 走看看