Tomcat的简单说明

TOMCAT

CGI:公共网关接口,服务器和请求处理程序之间传输数据的一种标准。

配置文件

server.xml #主要配置文件
context.xml #默认context配置
tomcat-users.xml #tomcat管理用户配置
catalina.policy #当基于-security选项启动tomcat时读取此文件,是java的安全策略文件
catalina.properties #java属性定义,设定类加载器路径,安全包列表和一些调整性能的参数
logging.properties #日志配置

tomcat的配置层次

<Server><!--顶级组件,表示运行的tomcat实例-->
    <Service><!--将Connector关联至engine,可以配置多个Connector,只能有一个engine-->
        <Connector /><!--连接器,配置监听的端口-->
        <Engine><!--核心容器组件,负责通过Connector接收请求,处理请求-->
            <Host><!--虚拟主机配置-->
                <Context><!--定义应用程序,配置此项指定对应的应用根目录,以及一些额外属性(部署方式等)-->
                </Context>
                <Valve/><!--拦截请求并处理-->
            </Host>
            <Realm></Realm><!--关联一个认证库,实现用户的认证和授权-->
        </Engine>
    </Service>
</Server>
<?xml version="1.0" encoding="UTF-8"?>
<!--
启动一个server实例,监听8005端口以接收shutdown命令,各个server的定义不能使用同一个端口,可以使用telnet发送shutdown命令来关闭此实例,基于安全,通常不允许远程操作
 -->
<Server port="8005" shutdown="SHUTDOWN">

  <!--
  定义一个service的名称

   -->
  <Service name="Catalina">

    <!-- 
    连接器类型:http连接器,ajp连接器,ssl连接器,proxy连接器,一个引擎可以有多个连接器以使用多种请求方式。
    连接器的属性:
    address:指定连接器监听的地址
    maxThreads:支持的最大并发连接数,默认为200
    port:监听的端口
    protocol:连接器使用的协议,默认为http/1.1,ajp协议时通常为AJP/1.3
    redirectPort:如果某连接器支持的协议为http,当接收到https请求时则转发至此端口
    connectionTimeout:等待客户端发送请求的超时时间,默认为60000,单位毫秒
    enableLookups:是否通过request.getRemoteHost()进行dns查询以获取客户端的主机名,默认为true
    acceptCount:设置等待队列的最大长度,通常在tomcat所有线程均处于繁忙状态时,新请求将被至于等待队列
    -->
    <Connector port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />


    <!-- 
    servlet处理器的一个实例,即servlet引擎,需要配置一个非明确定义主机时的默认请求host,即defaultHost

    -->
    <Engine name="Catalina" defaultHost="localhost">
      <!--
      appBase:部署目录
      unpackWARs:自动解压
      autoDeploy:自动部署
      -->

      <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 &quot;%r&quot; %s %b" />
        <!--
         应用程序配置
         path:访问路径
         docBase:应用相对host的存放目录
         reloadable:允许重新加载
         -->
        <Context path="" docBase="ROOT" reloadable="true" />

      </Host>
    </Engine>
  </Service>
</Server>

AJP协议

apache jserv protocal:二进制协议,用于tomcat与apache建立通信,用于使用httpd反向代理用户请求至tomcat时,在httpd和tomcat之间使用。

默认应用

#需要配置用户权限
server status #获取应用程序信息,部署应用程序
host manager #管理虚拟主机

应用部署

静态部署:tomcat启动之前进行部署

动态部署:通过tomcat manager或者其他命令行工具进行部署

应用程序体系结构

webapps/ROOT 资源根目录
       /WEB-INF 私有资源目录,web.xml
               /classes class文件目录
               /lib jar依赖文件目录

tomcat的http连接器

基于java的http/1.1连接器
基于java的NIO http/1.1连接器
基于c/c++研发的native APR http/1.1连接器

tomcat集群

### session复制集群
1.在各节点的server.xml中,engine或者host容器中添加cluster节点配置,修改其中的多播地址
2.在各节点中为使用组播地址添加组播路由
route add -net addr netmask 255.255.255.255 dev eth0
3.在应用程序的web.xml中添加distributeable节点
注意:
该方式只适用于小型集群中
### session服务器
1.使用memcached-session-mamanger(msm),为tomcat添加session服务器
2.在context中定义manager节点
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容