1 Tomcat常用配置

本文详细介绍了Tomcat的常用配置,包括server.xml、context.xml、tomcat-users.xml和web.xml等文件的作用和配置要素。重点讲解了Server、Listener、GlobalNamingResources、Service、Connector、Engine、Host、Context等元素的功能和属性,以及如何通过它们定制Tomcat的行为。此外,还提供了配置实例和相关文件解析。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Tomcat常用配置

Tomcat依赖server.xml文件来启动server,一个Tomcat实例,核心就是启动容器Catalina。

Tomcat部署Webapp时,依赖context.xml和web.xml来部署Web应用。实际上,在部署任何一个webapp时,Tomcat自带的context.xml以及web.xml都会生效,同时webapp自带的META-INF/context.xml和WEB-INF/web.xml也会定义每个webapp的特定行为。

web.xml

context.xml

所有host下Context的默认配置信息;默认配置如下:

    <Context>
        <WatchedResource>WEB-INF/web.xml</WatchedResource>
    </Context>

tomcat-users.xml

Realm认证时用到的相关角色、用户和密码等信息;Tomcat自带的manager默认情况下会用到此文件;在Tomcat中添加/删除用户,为用户指定角色等将通过编辑此文件实现;

server.xml 详解

conf/server.xml 是 Servlet/JSP 容器 Tomcat 的主要配置文件,使用 XML 的方式描述了 WebApp 的运行方式。

在 server.xml 中的元素(element)和属性(properties)是区分大小写的,并且支持 Apache Ant 方式的变量替换(Apache Ant-style variable substitution)。在配置文件中还支持以 propnamepropnameDJVM CATALINA_BASE/conf/catalina.properties file 文件中的变量。

server.xml 元素包含四大类:

  1. 顶层类元素 - 是根元素, 表示一组与一个 有关的连接器。
  2. 连接器类元素 - ,客户端和容器类元素的通讯接口。
  3. 容器类元素 - 、 和 ,处理客户请求并且生成响应结果。
  4. 嵌套类元素 - 、 和 ,可以加入到容器中的元素。

文件结构:

    <Server>
        <Listener />
        <GlobaNamingResources></GlobaNamingResources
        <Service>
            <Executor />
            <Connector />
            <Engine>
                <Cluster />
                <Realm />
                <Realm />
                   <Host>
                       <Valve />
                       <Context />
                   </Host>
            </Engine>
        </Service>
    </Server>

Server 元素

<Server> 是 Tomcat 实例的顶层元素,由 org.apache.catalina.Server 接口定义,它可以包含一个或多个 <Service> 元素,并且不能做为任何元素的子元素。一个 <Server> 是一个提供完整JVM的独立组件,它可以代表整个容器,但它本身不是一个容器,不可以定义 <value><loggers> 之类的子组件。

属性说明:

属性说明
port指定一个端口,这个端口负责监听关闭 Tomcat 的请求
shutdown向以上端口发送的关闭服务器的命令字符串,通常为 SHUTDOWN
addressomcat监听shutdown命令的地址,默认为localhost
className指定实现org.apache.catalina.Server接口的类,默认值为org.apache.catalina.core.StandardServer

对于一个已经开启的 Tomcat 服务器,可以在 cmd 下使用 telnet localhost 8005 命令进行连接,然后输入 SHUTDOWN 命令就可以关闭服务器。

Listener

Listener即监听器,负责监听特定的事件,当特定事件触发时,Listener会捕捉到该事件,并做出相应处理。Listener通常用在Tomcat的启动和关闭过程。Listener可嵌在Server、Engine、Host、Context内。

常用属性:

属性说明
className指定实现org.apache.catalina.LifecycleListener接口的类

GlobalNamingResources

GlobalNamingResources用于配置JNDI。

Service 元素

Service包装Executor、n个Connector、1个Engine,Connector获取request,Engine处理request。Server可以包含多个Service组件

属性说明:

属性说明
name<Service>的名称
className指定实现org.apache.catalina.Service接口的类,默认值为org.apache.catalina.core.StandardService

Executor

Executor即Service提供的线程池,供Service内各组件使用,特别是Connector组件。

Connector 元素

是直接与用户交互的组件,负责接受用户请求和向客户返回响应结果。

属性说明:

属性说明
port 所监听的端口。在浏览器中可以通过输入 url:port 的方式提交给对应的 。因为浏览器的默认端口是 80,所以如果把 的 port 设成 80 的话,可以直接使用 url 进行访问,不用在后边再跟一个端口号。
protocol设定 Http 协议,默认是 HTTP/1.1。
minThreads服务器启动时创建的处理用户请求的线程数。
maxThreads可以创建的最大的处理用户请求的线程数。
minSpareThreads最小备用线程数。
maxSpareThreads最大备用线程数。
acceptCount当所有可以使用的处理请求的线程都被用光时,可以放到处理队列中的请求数,超过这个数的请求将不予处理,而返回 Connection refused 错误。
redirectPort服务器正在处理 http 请求时收到了一个 SSL 传输请求后重定向的端口号。(即当请求是 https 时,将它转发到的端口)。
enableLookups如果为 true,表示支持域名解析,则可以在 web 应用中通过调用 request.getRemoteHost() 进行 DNS 查询来得到远程客户端的实际主机名;若为 false 则不进行 DNS 查询,而是返回其 ip 地址。默认值为 true。
connectionTimeout等待超时的时间数(以毫秒为单位),如果为 -1 表示不限制客户连接的时间。

HTTP与AJP:

  • HTTP:监听browser发送的http请求;
  • AJP:其他WebServer(Apache)的servlet/jsp代理请求;

Engine 元素

它处理在同一个 中所有 元素接收到的客户请求。它匹配请求和自己的虚拟主机,并将请求发给对应的 处理,默认的主机是 localhost。

属性说明:

属性说明
nameengine的名称,对应目录 /conf/Catalina。
defaultHost默认的处理请求的虚拟主机,至少与下面一个Host的name属性一样。对应 /conf/Catalina/localhost。
Debug日志等级

Host 元素

一个 元素可以包含多个 元素,每个 元素定义一个虚拟主机,它包含一个或多个web应用。

属性说明:

属性说明
name虚拟主机名,对应目录 /conf/Catalina/localhost。
appBase指定虚拟主机的目录,默认为 /webapps。它将请求 url 与该虚拟主机的 进行匹配,并把请求转给对应的 来处理。
Debug日志等级。
autoDeploy默认为 true,表示如果有新的 Web 应用放入 appBase 并且 Tomcat 在运行的情况下,自动载入应用。
unpackWARs如果设置为 true,表示把war文件先展开再运行。如果为 false则直接运行 war 文件。

Context 元素

代表运行在虚拟主机上的单个 web 应用。一个 Host> 可以包含多个 元素。每个 web 应用有唯一个相对应的 代表 web 应用自身。

属性说明:

属性说明
pathWeb应用名,在使用 url 访问 下的web应用时,通过 http://localhst/website 的形式。其中 localhost 为上文所说的 的 name,而 website 就是这里的 path。也就是说当一具请求到来时, 先根据 host
docBaseWeb应用的具体存放路径
Debug日志等级。
autoDeploy默认为 true,表示如果有新的 web 应用放入 appBase 并且 Tomcat 在运行的情况下,自动载入应用。
unpackWARs如果设置为 true,表示把 war 文件先展开再运行。如果为 false 则直接运行 war 文件。
reloadable是否自动检测并重新部署Web项目( 设置为 true,Tomcat会自动监控Web项目的/WEB-INF/classes/和/WEB-INF/lib变化,当检测到变化时,会重新部署Web项目;reloadable默认值为 false:通常项目开发过程中设为true,项目发布的则设为false)

Cluster

Tomcat集群配置。

Realm

Realm可以理解为包含用户、密码、角色的”数据库”。Tomcat定义了多种Realm实现:

  • JDBC Database Realm
  • DataSource Database Realm
  • JNDI Directory Realm
  • UserDatabase Realm等

Valve

Valve可以理解为Tomcat的拦截器,而我们常用filter为项目内的拦截器。Valve可以用于Tomcat的日志、权限等。Valve可嵌在Engine、Host、Context内。

配置实例

conf/server.xml 配置文件

Server port="8005" shutdown="SHUTDOWN"> 
  <Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" /> 
  <Listener className="org.apache.catalina.core.JasperListener" /> 
  <Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" /> 
  <Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" /> 
  <Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" /> 

  <!-- 全局命名资源,来定义一些外部访问资源,其作用是为所有引擎应用程序所引用的外部资源的定义 -->
  <GlobalNamingResources>  
    <!-- 定义的一个名叫“UserDatabase”的认证资源,将conf/tomcat-users.xml加载至内存中,
        在需要认证的时候到内存中进行认证 --> 
    <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> 

  <!-- # 定义Service组件,同来关联Connector和Engine,一个Engine可以对应多个Connector,每个Service中只能一个Engine --> 
  <Service name="Catalina"> 
    <!-- 修改HTTP/1.1的Connector监听端口为80.客户端通过浏览器访问的请求,只能通过HTTP传递给tomcat。  --> 
    <Connector port="80" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" /> 
    <Connector port="8009" protocol="AJP/1.3" redirectPort="8443" /> 
    <Engine name="Catalina" defaultHost="test.com"> 
    <!-- 修改当前Engine,默认主机是,www.test.com  --> 
    <Realm className="org.apache.catalina.realm.LockOutRealm"> 
        <Realm className="org.apache.catalina.realm.UserDatabaseRealm" 
               resourceName="UserDatabase"/> 
    </Realm> 
    <!-- # Realm组件,定义对当前容器内的应用程序访问的认证,通过外部资源UserDatabase进行认证   -->
      <Host name="test.com"  appBase="/web" unpackWARs="true" autoDeploy="true"> 
      <!--  定义一个主机,域名为:test.com,应用程序的目录是/web,设置自动部署,自动解压    --> 
        <Alias>www.test.com</Alias> 
        <!--    定义一个别名www.test.com,类似apache的ServerAlias --> 
        <Context path="" docBase="www/" reloadable="true" /> 
        <!--    定义该应用程序,访问路径"",即访问www.test.com即可访问,网页目录为:相对于appBase下的www/,
            即/web/www,并且当该应用程序下web.xml或者类等有相关变化时,
            自动重载当前配置,即不用重启tomcat使部署的新应用程序生效  --> 
        <Context path="/bbs" docBase="/web/bbs" reloadable="true" /> 
        <!--  定义另外一个独立的应用程序,访问路径为:www.test.com/bbs,该应用程序网页目录为/web/bbs   --> 
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/www/logs" 
               prefix="www_access." suffix=".log" 
               pattern="%h %l %u %t &quot;%r&quot; %s %b" /> 
        <!--   定义一个Valve组件,用来记录tomcat的访问日志,日志存放目录为:/web/www/logs,
            如果定义为相对路径则是相当于$CATALINA_HOME,并非相对于appBase,这个要注意。
            定义日志文件前缀为www_access.并以.log结尾,pattern定义日志内容格式,
            具体字段表示可以查看tomcat官方文档 --> 
      </Host> 
      <Host name="manager.test.com" appBase="webapps" unpackWARs="true" autoDeploy="true"> 
      <!--   定义一个主机名为manager.test.com,应用程序目录是$CATALINA_HOME/webapps,自动解压,自动部署 --> 
        <Valve className="org.apache.catalina.valves.RemoteAddrValve" allow="172.23.136.*" /> 
        <!--   定义远程地址访问策略,仅允许172.23.136.*网段访问该主机,其他的将被拒绝访问  --> 
        <Valve className="org.apache.catalina.valves.AccessLogValve" directory="/web/bbs/logs" 
               prefix="bbs_access." suffix=".log" 
               pattern="%h %l %u %t &quot;%r&quot; %s %b" /> 
        <!--   定义该主机的访问日志   --> 
      </Host> 
    </Engine> 
  </Service> 
</Server> 

conf/tomcat-users.xml配置文件

    <?xml version='1.0' encoding='utf-8'?> 
    <tomcat-users> 
      <role rolename="manager-gui" /> 
      <!--  定义一种角色名为:manager-gui  --> 
      <user username="cz" password="manager$!!110" roles="manager-gui" /> 
      <!--  定义一个用户的用户名以及密码,并赋予manager-gui的角色    --> 
    </tomcat-users> 

Reference

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值