码迷,mamicode.com
首页 > 其他好文 > 详细

tomcat配置文件

时间:2015-08-05 22:36:23      阅读:298      评论:0      收藏:0      [点我收藏+]

标签:tomcat

一、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配置文件的层次结构:

<server>

     <service>

     <connector />

     <engine>

     <host>

     <context></context>

     </host>

     <host>

     <context></context>

     </host>

     </engine>

     </service>

</server>

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:

<Connector connectionTimeout="20000" port="8088" protocol="HTTP/1.1" redirectPort="8443"/>

   (2)AJP(Apache Jserv Protocol)的connector:AJP为二进制协议,专用于tomcat与apache建立通信的, 在httpd反向代理用户请求至tomcat时使用(可见Nginx反向代理时不可用AJP协议)。

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

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。


本文出自 “创新分享驰骋里外” 博客,请务必保留此出处http://10554846.blog.51cto.com/10544846/1682017

tomcat配置文件

标签:tomcat

原文地址:http://10554846.blog.51cto.com/10544846/1682017

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!