一、tomcat的配置文件目录与目录下的详细内容
[root@py conf]# pwd
/usr/local/tomcat/conf
[root@py conf]# ls
Catalina context.xml tomcat-users.xml
catalina.policy logging.properties web.xml
catalina.properties server.xml
1、server.xml详解
server.xml为核心配置文件
1.1 server.xml配置文件的层次结构:
1.2、server.xml组件类别:
顶级组件:位于整个配置的顶层,如server。
容器类组件:可以包含其它组件的组件,如service、engine、host、context。
连接器组件:连接用户请求至tomcat,如connector。
被嵌套类组件:位于一个容器当中,不能包含其他组件,如Valve、logger。
1.3、组件详解:
engine:核心容器组件,catalina引擎,负责通过connector接收用户请求,
并处理请求,将请求转至对应的虚拟主机host。
host:类似于httpd中的虚拟主机;一般而言支持基于FQDN的虚拟主机。
context:定义一个应用程序,是一个最内层的容器类组件(不能在嵌套);配置context的主要目的指定对应对的webapp的根目录,类似于httpd的alias。其还能为webapp指定额外的属性,如部署方式等。
connector:接收用户请求,类似于httpd的listen配置监听端口的;
service(服务):将connector关联至engine;因此一个service内部可以有多个connector,但只能有一个引擎engine。参见,server.xml,service内部有两个connector,一个engine。因此,一般情况下一个server内部只有一个service;一个service内部只有一个engine,但一个service内部可以有多个connector。事实上一个server内部可以有多个service;每个service内部只有一个engine,但一个service内部可以有多个connector。
server:表示一个运行于JVM中的tomcat实例。
Valve:阀门,拦截请求并在将其转至对应的webapp前进行某种处理操作,可以用于任何容 器中,比如记录日志(access log valve)、基于IP做访问控制(remote address filter valve)。
logger:日志记录器,用于记录组件内部的状态信息;可以用于除context外的任何容器中。
realm:可以用于任意容器类的组件中,关联一个用户认证库,实现认证和授权。
可以关联的认证库有两种:UserDatabaseRealm、MemoryRealm和JDBCRealm。
UserDatabaseRealm:使用JNDI自定义的用户认证库。
MemoryRealm:认证信息定义在tomcat-users.xml中。
JDBCRealm:认证信息定义在数据库中,并通过JDBC连接至数据库中查找认证用户。
1.4、connector种类:
(1) http的connector:
(2)AJP(Apache Jserv Protocol)的connector:AJP为二进制协议,专用于tomcat与apache建立通信的, 在httpd反向代理用户请求至tomcat时使用(可见Nginx反向代理时不可用AJP协议)。
1.5、其中的属性介绍
(1)Connector的属性说明:
port:监听的端口,默认为0
address:指定连接器监听的地址,默认为所有地址(即0.0.0.0)
protocol:连接器使用的协议,默认为http/1.1.定义AJP协议时通常为AJP/1.3
redirectPort:如果莫连接器支持的协议为HTTP,当接收客户端发来的HTTPS请求时,则转发至此属性定义的端口。
maxThreads:支持的最大并发连接数,默认为200,这个在正式服务器需要调整。
connectionTimeout:等待客户端发送请求的超时时间,单位为毫秒,默认为60000,即1分钟。
enableLookups:是否通过request.getRemoteHost()进行DNS查询以获取客户端主机名,默认为true,这个影响效率最好关掉。
acceptCount:设置等待队列的最大长度,通常在tomcat所有处理线程均处于繁忙状态时,新发来的请求将被放置于此等待队列中。
(2)host的属性说明:
name:host的名称,一般为name="localhost"。
appBase:应用程序存放路径,一般为appBase="webapps" ,相对于CATALINA_HOME而言的,也可以写绝对路径。
autoDeploy:在tomcat启动时,是否自动部署。
unpackWARS:是否自动解压war文件,一般为unpackWARS="true"。
xmlValidation:是否启动xml的校验功能,一般xmlValidation="false"。
xmlNamespaceAware:检测名称空间,一般xmlNamespaceAware="false"。
(3)context的属性说明:
docBase:相应的Web应用程序的存放位置,也可以使用相对路径,起始路径为此Context所属Host中appBase定义的路径。
path:相对于Web服务器根路径而言的URI,如果为空,则表示为此webapp的根路径。
reloadable:是否允许重新加载此context相关的web应用程序的类,默认为false
2.web.xml
web.xml为部署于此tomcat实例上的所有webApp提供默认部署描述符;通常用于为webapp提供基本的servlet定义和MIME映射表等。
3.context.xml
context.xml:上下文配置文件,为部署于此tomcat实例上的所有webApp(web应用程序)提供默认配置文件;
context.xml常用于定义会话管理器、JDBC以及Realm等。但每个webApp均可有自己独有的context.xml,通常放置于每个webApp目录的META-INF。