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

tomcat工作原理及目录文件介绍

2018-09-02 15:25 639 查看
tomcat工作原理及目录文件介绍

1、tomcat背景

自从JSP发布之后,推出了各式各样的JSP引擎。Apache Group在完成GNUJSP1.0的开发以后,开始考虑在SUN的JSWDK基础上开发一个可以直接提供Web服务的JSP服务器,当然同时也支持Servlet, 这样tomcat就诞生了。tomcat是jakarta项目中的一个重要的子项目,其被JavaWorld杂志的编辑选为2001年度最具创新的java产品,同时它又是sun公司官方推荐的servlet和jsp容器,因此其越来越多的受到软件公司和开发人员的喜爱。servlet和jsp的最新规范都可以在tomcat的新版本中得到实现。其次,tomcat是完全免费的软件,任何人都可以从互联网上自由地下载。tomcat与Apache的组合相当完美。

2、tomcat Server处理一个http请求的过程

假设来自客户的请求为:http://localhost:8080/wsota/wsota_index.jsp
1、请求被发送到本机端口8080,被在那里侦听的CoyoteHTTP/1.1 Connector获得
2、Connector把该请求交给它所在的Service的Engine来处理,并等待来自Engine的回应
3、 Engine获得请求localhost/wsota/wsota_index.jsp,匹配它所拥有的所有虚拟主机Host
4、Engine匹配到名为localhost的Host(即使匹配不到也把请求交给该Host处理,因为该Host被定义为该Engine的默认主机)
5、 localhost Host获得请求/wsota/wsota_index.jsp,匹配它所拥有的所有Context
6、Host匹配到路径为/wsota的Context(如果匹配不到就把该请求交给路径名为""的Context去处理)
7、path="/wsota"的Context获得请求/wsota_index.jsp,在它的mapping table中寻找对应的servlet
8、Context匹配到URLPATTERN为*.jsp的servlet,对应于JspServlet类
9、构造HttpServletRequest对象和HttpServletResponse对象,作为参数调用JspServlet的doGet或doPost方法
10、Context把执行完了之后的HttpServletResponse对象返回给Host
11、Host把HttpServletResponse对象返回给Engine
12、Engine把HttpServletResponse对象返回给Connector
13、Connector把HttpServletResponse对象返回给客户browser

3、tomcat目录详细解析

3.1、bin目录

bin目录主要用来存放tomcat的命令,很多环境变量也在此处设置。以.sh结尾的代表Linux下的命令;以.bat结尾的代表Windows下的命令。其中startup.bat代表windows系统下启动tomcat的命令;shutdown.bat代表Windows系统下关闭tomcat的命令。同理startup.sh代表Linux下的启动tomcat的命令;shutdown.sh代表linux下关闭tomcat的命令。详细介绍如下所示。
bin目录中的脚本说明
文件名称文件作用
catalina.sh
tomcat主要脚本,用于启动和关闭tomcat服务器
startup.sh
启动运行tomcat实例,相当于 catalina.sh start
shutdown.sh
停止tomcat实例的运行,相当于 catalina.sh stop
daemon.sh
tomcat服务的启动脚本,可以复制到/etc/init下使用
catalina-tasks.xml
定义tomcat载入的库文件,类文件
version.sh
查看当前tomcat的版本信息
configtest.sh
校验tomcat配置文件server.xml的格式、内容等是否合法、正确
setclasspath.sh
catalina.sh依赖这个脚本来设置tomcat的classpath等环境变量
digest.sh
用于生成加密过的tomcat用户密码
tool-wrapper.sh
一般和digest脚本结合使用
bootstrap.jar
tomcat启动时所依赖的一个类,在启动tomcat时会发现Using CLASSPATH: 是加载的这个类
commons-daemon.jar
jsvc工具所依赖的java类
commons-daemon-native.tar.gz
jsvc工具,可以使tomcat以守护进程方式运行,需单独编译安装
tomcat-juli.jar
是一款在使用tomcat开发时十分关键的一款jar包
tomcat-native.tar.gz
使tomcat可以使用apache的apr运行库,以增强tomcat的性能需单独编译安装

3.2、conf目录

conf目录主要存放tomcat服务器全局配置的各种文件,详见以下说明。
conf目录中配置文件说明
catalina.policy
tomcat 安全机制的配置文件,默认情况下 tomcat 是非安全模式运行的,只有当tomcat用-security命令行参数启动时这个文件才会被使用,该文件可以配置tomcat对文件系统中目录或文件的读、写执行等权限,及对一些内存,session等的管理权限
catalina.properties
catalina.properties 是 Catalina 的配置文件,主要有安全设置、类加载设置、不需要扫描的类设置、字符缓存设置四大块。配置tomcat的classpath等
context.xml
tomcat的默认context容器,可被所有的web应用程序使用.这个文件默认地可以设置到何处访问各web应用程序中的web.xml文件。context.xml 在 tomcat 6.0 时从 server.xml 中分离出来,主要用于项目部署的配置。
server.xml
tomcat中最重要的配置文件,也是最常用的一个,用于对整个容器进行相关的配置,解析器用这个文件在启动时根据规范"创建"容器
web.xml
tomcat的应用程序的部署描述符文件,是所有Web项目的缺省配置文件。
tomcat-users.xml
tomcat的角色(授权用户)配置文件,用于访问tomcat管理应用程序时的安全性设置,用server.xml中引用的默认的用户数据库域(UserDatabase Realm)使用它,所有的凭据都是默认被注释的。
tomcat-users.xsd
定义了 tomcat-users.xml 所使用到的标签
logging.properties
tomcat 的日志配置文件,用于配置tomcat的日志输出方式和日志级别。
jaspic-providers.xml
tomcat 实现了 JASPIC 1.1 Maintenance Release B 标准,并通过这个配置文件集成第三方 JASPIC 身份验证
jaspic-providers.xsd
定义了 jaspic-providers.xml 所使用到的标签

3.3、lib目录

lib目录下主要存放tomcat服务器所需要的所有Jar包。我们在连接数据库时常常烦恼每创建一个项目就要引入一个对应的oracle的Jar包或MySQL的Jar。但是如果你把这两个Jar包放在此目录下,就可以引入一次,以后再创建项目时不需要每次都引入Jar包。

3.4、logs目录

logs目录用来存放tomcat在运行过程中产生的日志文件,非常重要的是在控制台输出的日志。(清空不会对tomcat运行带来影响) 在windows环境中,控制台的输出日志在catalina.xxxx-xx-xx.log文件中。在linux环境中,控制台的输出日志在catalina.out文件中

3.5、temp目录

temp 文件夹用于存放 tomcat 在运行过程中产生的 临时文件。temp 文件夹可以被清空,但是不能随意删除,否则会有未知错误发生。

3.6、webapps目录

webapps目录是tomcat默认存放应用程序的目录,好比apache的默认网页存放路径是/var/www/html一样,当tomcat启动时会去加载webapps目录下的应用程序。可以以文件夹、war包、jar包的形式发布应用。当然,你也可以把应用程序放置在磁盘的任意位置,在配置文件中映射好就行。该目录中介绍如下
webapps目录介绍
docs
tomcat文档存放目录
examples
tomcat自带的一个独立的web应用程序例子存放位置
host-manager
tomcat的主机管理应用程序存放位置
host-manager目录中文件介绍
META-INF
整个应用程序的入口,用来描述jar文件的信息
context.xml
当前应用程序的context容器配置,它会覆盖tomcat/conf/context.xml中的配置
WEB-INF
用于存放当前应用程序的私有资源
images
存放应用程序相关图片文件
index.jsp
应用程序的网页文件
manager.xml
应用程序的管理配置文件
manager
tomcat的管理应用程序
ROOT
指tomcat的应用程序的根,如果应用程序部署在ROOT中,则可直接通过http://ip:port 访问到

3.7、work目录

work目录用于存放JSP应用程序在部署时编译后产生的class文件,清空work目录,然后重启tomcat,可以达到清除缓存的作用。

3.8、LICENSE 文件

LICENSE 文件是tomcat 开源许可证文件。

3.9、NOTICE 文件

NOTICE 文件是tomcat 说明文件。

3.10、RELEASE-NOTES 文件

RELEASE-NOTES 文件是tomcat 版本说明文件。

3.11、RUNNING.txt 文件

RUNNING.txt 文件是tomcat 帮助文件(使用指南)。

4、catalina.sh | catalina.bat脚本文件使用方法

语法格式:catalina.sh 选项
例如:catalina.sh start #启动tomcat
catalina.sh脚本可用选项如下:
catalina.sh脚本选项及说明
选项名称选项作用
debug
以debug模式启动
debug -security
启用catalina.policy文件
jpda start
以jpda(Java Platform Debugger Architecture)调试器的模式启动
run
即使是在linux上,也不会将输出重定向到日志文件,就像和windows上(那个一直开着的黑窗口)一样的效果
start
启动tomcat
stop n
停止tomcat,最多有n秒的延迟来处理释放资源等的操作
stop
相当于 stop 5
stop n -force
停止tomcat,最多n秒延迟,n秒之后会强制kill掉tomcat
stop -force
相当于 stop 5 --force
configtest
检测配置文件${catalina.home}/conf/server.xml语法
version
tomcat版本信息

5、tomcat环境变量说明

tomcat环境变量说明
环境变量名称环境变量说明
CATALINA_HOME
tomcat安装目录
CATALINA_OPTS
一般是传递JVM参数使用的,比如-Xmx256M
CATALINA_TMPDIR
tomcat临时文件目录
JAVA_HOME
JDK安装目录
JRE_HOME
JRE安装路径
JAVA_OPTS
传递JVM参数使用的,比如-Xmx256M
JPDA_TRANSPORT
JPDA调试器使用的传输协议
JPDA_ADDRESS
制定和catalina.sh jpda start 一起使用的jpda地址
JSSE_HOME
指定用于https使用的Java Secure SocketsExtension的位置
CATALINA_PID
进程描述符位置
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息