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 "%r" %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节点