tomcat Server.xml

<?xml version="1.0" encoding="UTF-8"?>
<Server port="8005" shutdown="SHUTDOWN">
	<!-- Listener监听器 -->
    <!--
  VersionLoggerListener:当Tomcat启动时,该监听器记录Tomcat、Java和操作系统的信息。该监听器必须是配置的第一个监听器。
  AprLifecycleListener:Tomcat启动时,检查APR库,如果存在则加载。APR,即Apache Portable Runtime,是Apache可移植运行库,可以实现高可扩展性、高性能,以及与本地服务器技术更好的集成。
  JasperListener:在Web应用启动之前初始化Jasper,Jasper是JSP引擎,把JVM不认识的JSP文件解析成java文件,然后编译成class文件供JVM使用。
  JreMemoryLeakPreventionListener:与类加载器导致的内存泄露有关。
  GlobalResourcesLifecycleListener:通过该监听器,初始化< GlobalNamingResources>标签中定义的全局JNDI资源;如果没有该监听器,任何全局资源都不能使用。< GlobalNamingResources>将在后文介绍。
  ThreadLocalLeakPreventionListener:当Web应用因thread-local导致的内存泄露而要停止时,该监听器会触发线程池中线程的更新。当线程执行完任务被收回线程池时,活跃线程会一个一个的更新。只有当Web应用(即Context元素)的renewThreadsWhenStoppingContext属性设置为true时,该监听器才有效。-->
  
	<Listener className="org.apache.catalina.startup.VersionLoggerListener" />
	<Listener className="org.apache.catalina.core.AprLifecycleListener" SSLEngine="on" />
	<Listener className="org.apache.catalina.core.JreMemoryLeakPreventionListener" />
	<Listener className="org.apache.catalina.mbeans.GlobalResourcesLifecycleListener" />
	<Listener className="org.apache.catalina.core.ThreadLocalLeakPreventionListener" />
	<!-- 全局资源 -->
	<GlobalNamingResources>
		<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>
	<!-- Tomcat服务,name=Catalina,用于 绑定 连接器与 Engine -->
	<Service name="Catalina">
		<!-- 
			Tomcat连接器
			port:端口号
			protocol:协议
			connectionTimeout:连接超时时间(单位毫秒)
			redirectPort:如果使用https://来访问这个8080端口,就会重定向到8443这个端口,8443也得有对应的连接器,否则转发不过去
			minThread	服务器启动时创建的处理请求的线程数
			maxThread	最大可以创建的处理请求的线程数
			enableLookups	如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址
			acceptCount	指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理
			SSLEnabled 是否开启 sll 验证,在Https 访问时需要开启。
		-->
		<Connector port="8080" protocol="HTTP/1.1"
				   connectionTimeout="20000"
				   redirectPort="8443" />
		<!--
			protocol="AJP/1.3",是Apache和Tomcat之间在进行反向代理的时候的一个私有协议(体积更轻,性能更快)
		-->
		<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />
		
		<!--
			Engine引擎
			name="Catalina"核心引擎
			defaultHost:默认host,host就是虚拟主机,基于域名区分,当没有域名能区分的时候,就将请求发给默认的host
		-->
		<Engine name="Catalina" defaultHost="localhost">
			<!--
				Realm:领域
				UserDatabaseRealm将UserDatabase的数据注入到引擎中,便于引擎访问UserDatabase
			-->
			<Realm className="org.apache.catalina.realm.LockOutRealm">
			<Realm className="org.apache.catalina.realm.UserDatabaseRealm"
				   resourceName="UserDatabase"/>
			</Realm>
			<!--
				appBase=webapps,这也就是为什么可以直接解析webapps的原因
				unpackWARs=true,存在war包则解析
				autoDeploy=false,自动部署
			-->
			<Host name="localhost"  appBase="webapps"
				unpackWARs="true" autoDeploy="true">
			<Logger /> <!-- 日志配置-->
			<!-- 
				上下文配置
				一个host 下可以配置多个Context ,每个Context 都有其独立的classPath。相互隔离,以免造成ClassPath 冲突。
			-->
			<Context "/test" path=""/> 
			<!--
				Valve:阀门也可以理解为一个过滤器,放在了host里面则服务于整个host,放在Context内则只服务于那一个Context
				作用:打印请求日志,IP过滤,限流等	
				具体配置要基于具体的Valve 接口的子类。以下即为一个访问日志的Valve.
			-->
			<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>


在这里插入图片描述

Server节点

描述:Server代表一个Tomcat实例(一个JVM)所以server.xml中唯一一个最外层的元素(唯一)

功能:提供接口让客户端能访问Server包含的Service,维护各个Service的生命周期等。

属性:

  • port: 指定端口监听关闭tomcat的请求,设为-1可以禁掉该端口。
  • shutdown: 关闭tomcat的发送的字符串
Service

描述:一个Server节点可以包含多个Service节点。不同的Service所监听的端口必须是不能重复的。

功能:一个Service可以理解为Engine和Connector的容器。每个Connector通过一个特定的端口和协议接收入站请求交将其转发至关联的Engine进行处理。

属性:

  • name:指定service 的名字
    会默认生成一个名为Catalina的Service

Service包含Connector和Engine两个节点。

Connector

描述:一个Service可以包含多个Connector,Connector有多种类型

  • HTTP连接器
  • SSL连接器
  • AJP 1.3连接器
  • proxy连接器

他用来表示客户端和service之间的连接。

HTTP connector 示例:

<Connector port="8080" protocol="HTTP/1.1"
      maxThreads="150" connectionTimeout="20000"
      redirectPort="8443" URIEncoding="UTF-8"/>

SSL connector 示例:

<Connector port="8443"
    maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
    enableLookups="false" acceptCount="100" debug="0" scheme="https"
    secure="true" clientAuth="false" sslProtocol="TLS" />

AJP connector 示例:

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

在默认的Service中包含两个Connector:
分别是

<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000"redirectPort="8443"/>
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>

此时Tomcat监听的HTTP请求,协议是HTTP/1.1,端口是8080,转发HTTPS请求到8443端口。

配置<Connector port="8009" protocol="AJP/1.3" redirectPort="8443"/>客户端就可以通过8009端口使用AJP协议访问tomcat。

AJP协议:
AJP协议负责和其他http服务器建立连接,把tomcat服务器和其他http服务器连接时,就需要这个,之所以使用Tomcat和其他服务器集成,是因为Tomcat可以用作Servlet/JSP容器,但是对静态资源的处理速度较慢,不如Apache和IIS等HTTP服务器;因此常常将Tomcat与Apache等集成,前者作Servlet容器,后者处理静态资源,而AJP协议便负责Tomcat和Apache的连接

功能:接收连接请求,创建Request和Response对象用于和请求端交换数据,然后分配线程让Engine处理请求并把Request和Response对象传递给Engine

主要属性属性:

  • port 指定服务器要创建的端口号,并在改端口监听客户端的请求。
  • minProcessors 服务启动时创建处理请求的线程数目。
  • maxProcessors 最大可创建的处理请求线程数目。
  • enableLookups true:进行DNS查询得到远程客户端的实际主机名 false不进行查询。
  • redirectPort 如果某连接器支持的协议是HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的端口
  • connectionTimeout 等待客户端发送请求的超时时间,单位为毫秒,默认为60000,即1分钟;
Engine

描述:一个Service 对应一个Engine。

功能:一个Engine从一个或者多个Connector中接收请求并处理,并将完成的响应返回给Connector。

主要属性:

  • defaultHost 默认host的名字。
  • name 用于日志和错误信息,在Server中唯一
  • startStopThreads 该Engine启动子Host默认开启的线程
Host

描述:一个Engine对应多个Host ,每个Host代表Engine的一个虚拟主机。Host组件至少有一个,且其中一个的name必须与Engine组件的defaultHost属性相匹配。

功能:用用来运行多个web应用,负责Web应用的生命周期。

tip: 虚拟主机是一种在一个web服务器上服务多个域名的机制,对每个域名而言,都好象独享了整个主机。实际上,大多数的小型商务网站都是采用虚拟主机实现的,这主要是因为虚拟主机能直接连接到Internet并提供相应的带宽,以保障合理的访问响应速度,另外虚拟主机还能提供一个稳定的固定IP。

主要属性:

  • name 指定虚拟主机的主机名
  • unpackWARs 是否将war文件解压,true为运行解压war文件后灯文件夹,false- 直接运行war文件。
  • autoDeploy 是否自动部署
  • appBase 此虚拟Host的WebApp存放路径。

若只配置appBase,不配Context 的docBase(appBase和docBase二选一就可以了),则appBase的每个文件夹里都代表一个应用.这个目录下面的.war文件将被自动解压缩并部署为应用。

Context

描述:一个Host可以对应多个Context,Context表示在特定的虚拟主机上运行的一个Web应用。
功能:

主要属性:

  • path 指定Web应用的URL入口 (多指项目名)
  • docBase 指定Web应用的文件路径,可以是绝对路径,也可以是相对路径(相对该Context所在的Host的appBase属性值)
  • reloadable 若此属性为true,tomcat在运行状态下回监视WEB-INF/classes和WEB-INF/lib目录下class的文件改动,若有文件更新服务器会重载Web应用

例子:在默认Host标签中添加Context

<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true">
     <Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
                       prefix="localhost_access_log." suffix=".txt"
                       pattern="%h %l %u %t "%r" %s %b"/>
    <Context path="/test" reloadable="true" docBase="/Users/WLW/tomcat/webapps2">
    
    </Context>
</Host>

/Users/WLW/tomcat/webapps2下创建test.html。

访问http://localhost:8080/test/test.html



详解Tomcat 配置文件server.xml

Tomcat 7 server.xml 配置文件详解

Tomcat的server.xml介绍

tomcat server.xml配置

tomcat配置文件server.xml详解和部署简介

Tomcat 6 —— Realm域管理

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值