您的位置:首页 > 运维架构 > Tomcat

(三)Tomcat源码解析 - Tomcat基础知识介绍

2015-02-26 13:14 281 查看
一、Tomcat目录结构

1、bin: 存放启动和关闭tomcat脚本

Catalina:主要的脚本,用以启动和停止服务,供其他脚本调用。

Cpappent:其他脚本调用该脚本在Tomcat启动前动态设置classpath,允许用户在同一个安装下通过设置配置文件来重写该配置参数,各用户之间的设置互不影响。

Digest:该脚本用于创建同期管理验证的摘要密码,通过加密密码提高安全性,容器管理安全机制允许授权用户、阻止非法用户。Tomcat服务器执行用户身份检查和用户授权。

jasper和jasc:这两个命令用以预编译JSP为Servlet文件,为了提高服务器初始响应速度,预编译的文件在Tomcat启动时被保存下来,当第一次被访问时被编译。因此,JSP文件大小被最小化。

startup和shutdown:这两个脚本调用Catalina脚本来启动和停止服务,使用可执行文件方便操作,代替命令行的执行方式,该命令在安装时被设置在开始菜单中,作为快捷方式,调用bootstap来启动服务。

tool-warpper:该命令允许相同环境中使用命令行方式进行操作。

2、conf:存放不同的配置文件(server.xml和web.xml)

(1)server.xml - Tomcat的全局配置文件 (2)web.xml - 在Tomcat中配置不同的关系环境

server.xml是Tomcat的主配置文件.完成两个目标:

1 提供Tomcat组件的初始配置.

2 说明Tomcat的结构,含义,使得Tomcat通过实例化组件完成起动及构建自身, 如在server.xml所指定的

Server:

1.port 指定一个端口,这个端口负责监听关闭tomcat的请求

2.shutdown 指定向端口发送的命令字符串

Service:

1.name 指定service的名字

<Server port="8005" shutdown="SHUTDOWN">

<Service name="Catalina">

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

</Service>

</Server>

Connector (表示客户端和service之间的连接):

1.port 指定服务器端要创建的端口号,并在这个断口监听来自客户端的请求

2.minProcessors 服务器启动时创建的处理请求的线程数

3.maxProcessors 最大可以创建的处理请求的线程数

4.enableLookups 如果为true,则可以通过调用request.getRemoteHost()进行DNS查询来得到远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址

5.redirectPort 指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号

6.acceptCount 指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,超过这个数的请求将不予处理

7.connectionTimeout 指定超时的时间数(以毫秒为单位)

Engine (表示指定service中的请求处理机,接收和处理来自Connector的请求):

defaultHost 指定缺省的处理请求的主机名,它至少与其中的一个host元素的name属性值是一样的

<Engine name="Catalina" defaultHost="localhost">

<Host name="localhost" appBase="webapps" unpackWARs="true" autoDeploy="true" xmlValidation="false" xmlNamespaceAware="false">

<Context path="/stdpm" reload="true" docBase="D:\Workspace\product\dist" >

<Logger className="org.apache.catalina.logger.FileLogger" prefix="localhost_product_log." suffix=".txt" timestamp="true" />

</Context>

</Host>

</Engine>

Context (表示一个web应用程序):

1.docBase 应用程序的路径或者是WAR文件存放的路径

2.path 表示此web应用程序的url的前缀,这样请求的url为 :http://localhost:8080/path/****

3.reloadable 这个属性非常重要,如果为true,则tomcat会自动检测应用程序的/WEB-INF/lib 和/WEB-INF/classes目录的变化,自动装载新的应用程序,我们可以在不重启tomcat的情况下改变应用程序

Host (表示一个虚拟主机):

1.name 指定主机名

2.appBase 应用程序基本目录,即存放应用程序的目录

3.unpackWARs 如果为true,则tomcat会自动将WAR文件解压,否则不解压,直接从WAR文件中运行应用程序

Logger (表示日志,调试和错误信息):

1.className 指定logger使用的类名,此类必须实现org.apache.catalina.Logger 接口

2.prefix 指定log文件的前缀

3.suffix 指定log文件的后缀

4.timestamp 如果为true,则log文件名中要加入时间,如下例:localhost_log.2001-10-04.txt

web.xml

Tomcat可以让用户通过将缺省的web.xml放入conf目录中来定义所有关系环境的web.xml的缺省值.建立一个新的关系环境时,Tomcat使用缺省的web.xml文件作为基本设置和应用项目特定的web.xml(放在应用项目的WEB-INF/web.xml文件)来覆盖这些缺省值。

3、lib:存放Tomcat运行需要的库文件

4、logs:存放Tomcat执行时的LOG文件

5、temp:Tomcat运行时用于存放临时文件

6、webapps:Tomcat的主要Web发布目录(包括应用程序示例)

7、work:存放jsp编译后产生的class文件

二、Tomcat帮助文档

帮助文档目录地址: Tomcat根目录/webapps/docs/index.html

三、Tomcat端口设置

说明:当一个server需要部署2个或2个以上TOMCAT时,请按照本规则进行部署

目的:统一端口使用规则,避免端口冲突,合理规划端口资源,方便故障诊断

注意:

1.正式环境中,虽然AJP和Http仅会用到其中之一端口,但不要取消AJP或者Http端口

2.出现端口争用问题后,可以使用probe查看TOMCAT占用端口信息

3.有些操作系统,当端口出现争用情况后,OS可能会另外为TOMCAT分配一个端口

4.不要分配8000以下端口给TOMCAT,即使OS仅保护1024以下端口

5.正式环境部署,请参照端口TOMCAT端口管理表部署

6.443类端口可在http端口前统一加3即可。 例如,8080端口对应的443实际端口就是38080

四、TOMCAT账号管理

设置:

1.修改TOMCAT_HOME/conf/tomcat-users.xml

2.仅设置两个role:admin,manager。

3.创建一个管理账号,并加入admin,manager的role

4.tomcat的管理,发布,监控全部使用该管理账号

修改好的tomcat-users.xml文件示例

<?xml version='1.0' encoding='utf-8'?>

<tomcat-users>

<role rolename="admin"/>

<role rolename="manager"/>

<user username="admin" password="admin" roles="admin,manager"/>

</tomcat-users>

五、TOMCAT监控软件安装

监控软件:Lambda Probe (http://www.lambdaprobe.org/)

登陆账号: tomcat-users.xml文件中设置的user账号具有admin,manager的role

安装方法:1.以命令行方式启动的tomcat

在catalina.bat/catalina.sh中

在JAVA_OPTS项中添加-Dcom.sun.management.jmxremote

2.以服务方式启动的tomcat

在JAVA OPTIONS中添加 -Dcom.sun.management.jmxremote

3.将probe.war安装包放在tomcat_home/webapps下即可

管理界面:http://localhost:8080/probe

六、TOMCAT环境变量设置

(1)正确方法: 在需要运行的tomcat的catalina.sh/catalina.bat中设置JAVA_HOME变量

(2)在系统环境变量中设置CATALINA_HOME, CATALINA_BASE的影响: 导致被设置的服务器仅能在指定CATALINA_HOME目录中运行唯一的TOMCAT

(3)注意事项:

1、不要在正式系统中部署安装版的TOMCAT

2、不要在任何系统path变量中写入TOMCAT环境变量,包括CATALINA_HOME, CATALINA_BASE,JAVA_HOME

七、TOMCAT和JVM的配置

1.系统选型最重要:重要项目尽可能使用64位系统

64位系统JVM内存最高可以设置为3800MB左右

32位系统JVM内存最高可以设置为1500MB左右

单一TOMCAT 64位系统可以使用内存3800MB,32位仅能使用1500MB

2.根据系统物理内存大小合理设置下列五个参数catalina.sh/catalina.bat

-server -Xms300m -Xmx300m -XX:PermSize=100m -XX:MaxPermSize=100m

-Xms=-Xmx -XX:PermSize=-XX:MaxPermSize

正式服务器必须设置以上参数,以尽可能压榨服务器性能

以上参数经过长久验证,可以稳定运行在各种操作系统平台和JDK版本上

相关参数具体取值自己考虑,不要超过(物理内存-其他程序内存)的80%即可。

3.没有特殊理由,不要设置除上述五个参数之外的JVM参数

原因:1.无法保证各种操作系统平台的可移植性

2.过度干涉JVM内存管理会导致无法预料的后果

服务方式启动的TOMCAT配置方法(针对WINDOWS系统)

在JAVA选项中,设置JAVA OPTIONS,添加以下三个参数,每行一个,不能并列

-XX:PermSize=256m

-XX:MaxPermSize=256m

-Dcom.sun.management.jmxremote

Initial memory pool 1000

Maximum menory pool 1000

不要设置thread stack size ,该值依据操作系统会有很大不同 。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: