Tomcat体系架构

总结Tomcat的体系架构、处理http请求的过程、安装和配置、目录结构、设置压缩和对中文文件名的支持、以及Catalina这个名字的由来……等。

Tomcat和JVM:

一个Tomcat只会启动一个JVM,所有webapps公用一个JVM进程,所以System.exit()会导致影响同个Tomcat中的其他应用。Tomcat通过调用配置的JDK或JRE来启动JVM。

体系结构:

Server:A Server element represents the entire Catalina servlet container. (Singleton)

Service:它由一个或者多个Connector组成,以及一个Engine,负责处理所有Connector所获得的客户请求。

Connector

  • TOMCAT有两个典型的Connector,一个直接侦听来自browser的http请求,一个侦听来自其它WebServer的请求
  • Coyote Http/1.1 Connector 在端口8080处侦听来自客户browser的http请求
  • Coyote JK2 Connector 在端口8009处侦听来自其它WebServer(Apache)的servlet/jsp代理请求

Engine

  • Engine下可以配置多个虚拟主机Virtual Host,每个虚拟主机都有一个域名
  • 当Engine获得一个请求时,它把该请求匹配到某个Host上,然后把该请求交给该Host来处理
  • Engine有一个默认虚拟主机,当请求无法匹配到任何一个Host上的时候,将交给该默认Host来处理

Host

  • 代表一个Virtual Host,虚拟主机,每个虚拟主机和某个网络域名Domain Name相匹配
  • 每个虚拟主机下都可以部署(deploy)一个或者多个Web App,每个Web App对应于一个Context,有一个Context path
  • 当Host获得一个请求时,将把该请求匹配到某个Context上,然后把该请求交给该Context来处理
  • 匹配的方法是“最长匹配”,所以一个path==”"的Context将成为该Host的默认Context
  • 所有无法和其它Context的路径名匹配的请求都将最终和该默认Context匹配

Context

  • 一个Context对应于一个Web Application,一个Web Application由一个或者多个Servlet组成
  • Context在创建的时候将根据配置文件$CATALINA_HOME/conf/web.xml和$WEBAPP_HOME/WEB-INF/web.xml载入Servlet类
  • 当Context获得请求时,将在自己的映射表(mapping table)中寻找相匹配的Servlet类
  • 如果找到,则执行该类,获得请求的回应,并返回

另外一个架构图:

Tomcat Server处理一个http请求的过程

假设来自客户的请求为:

http://localhost:8080/wsota/wsota_index.jsp

1) 请求被发送到本机端口8080,被在那里侦听的Coyote HTTP/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匹配到URL PATTERN为*.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

安装和配置:

  1. 下载:tomcat.apache.org(分Unix 和 windows版)
  2. 解压到Windows或Unix目录下
  3. 配置端口:server.xml
  4. 配置Tomcat登录用户名密码:tomcat-user.xml, 

    <tomcat-users>

    <user name="admin" password="admin" roles="admin-gui,manager-gui" />

    </tomcat-users>

  5. 配置好JDK,配置JAVA_HOME环境变量
  6. 修改端口:<Connector port="80" protocol="HTTP/1.1" ……/>

  • 启动

    • Windows: startup.bat (可以在文件末尾加入pause指令,方便查看启动结果)
    • Unix: ./startup.sh(观察log:tail -f catalina.log)
  • 关闭
    • Windows: shutdown.bat
    • Unix: ./shutdown.sh

Tomcat目录结构

bin --- 存放tomcat启动关闭程序

conf --- 存放tomcat配置文件

lib --- tomcat运行需要jar包

logs --- tomcat日志文件

webapps --- 网站发布目录(所有网站可以发布到该目录)

work --- 存放工程运行时,产生数据文件(JSP翻译Servlet、Session持久化数据)

站点根目录:

-------  静态web资源、jsp

-------  WEB-INF目录

-------  classes目录 (保存,class文件)

--------  lib  目录 (当前网站需要jar包)

-------- web.xml (网站配置文件)

* WEB-INF目录不是必须的,没有java动态程序代码, 可以没有WEB-INF 目录

* WEB-INF目录下资源不能被浏览器直接访问

如何设置tomcat压缩:

通过设置tomcat/conf/server.xml设置响应数据压缩

<Connector port="80" protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443"

compression="on"

               compressionMinSize="256"

compressableMimeType="text/html,text/xml,application/javascript,text/css,text/plain,application/json"/>

注:compressionMinSize推荐值在150和1000之间

清除浏览器缓存,重启tomcat

支持下载文件名为中文的文件:

<Connector port="8080"

URIEncoding="utf-8"

protocol="HTTP/1.1"

connectionTimeout="20000"

redirectPort="8443" />

时间: 2024-11-06 08:33:25

Tomcat体系架构的相关文章

关于Tomcat的点点滴滴(体系架构、处理http请求的过程、安装和配置、目录结构、设置压缩和对中文文件名的支持、以及Catalina这个名字的由来……等)

总结Tomcat的体系架构.处理http请求的过程.安装和配置.目录结构.设置压缩和对中文文件名的支持.以及Catalina这个名字的由来--等. Tomcat和JVM: 一个Tomcat只会启动一个JVM,所有webapps公用一个JVM进程,所以System.exit()会导致影响同个Tomcat中的其他应用.Tomcat通过调用配置的JDK或JRE来启动JVM. 体系结构: Server:A Server element represents the entire Catalina ser

(转)关于Tomcat的点点滴滴(体系架构、处理http请求的过程、安装和配置、目录结构、设置压缩和对中文文件名的支持、以及Catalina这个名字的由来……等)

转自:http://itfish.net/article/41668.html 总结Tomcat的体系架构.处理http请求的过程.安装和配置.目录结构.设置压缩和对中文文件名的支持.以及Catalina这个名字的由来--等. Tomcat和JVM: 一个Tomcat只会启动一个JVM,所有webapps公用一个JVM进程,所以System.exit()会导致影响同个Tomcat中的其他应用.Tomcat通过调用配置的JDK或JRE来启动JVM. 体系结构: Server:A Server el

面向服务的体系架构SOA

面向服务的体系架构SOA 序言 在.Net的世界中,一提及SOA,大家想到的应该是Web Service,WCF,还有人或许也会在.NET MVC中的Web API上做上标记,然后泛泛其谈! 的确,微软的这些技术也确实推动着面向服务的世界发展,当然除了微软还有很多面向服务的开源技术,甚至在某些方面比微软做的更加优秀.那么什么是面向服务,面向服务的存在是为了解决什么问题呢? 说说SOA面向服务 SOA是由Garnter在1996年提出的一个概念,旨在让软件变的有弹性,能够迅速响应业务的需求,实现实

36 网络标准体系架构;37 WEB 工作过程

36 网络标准体系架构 定义 B/S: Browser/Server: 使用标准的规则(标准的浏览器,HTTP,)Apache, IIS,Tomcat, Ngix,  Lighttp C/S: Client/Server: 不一定需要标准,不想B/S 一样有标准:Client 不需要,Server 也不需要:各自按照各自需求配置即可::举例:QQ, 微信:OUTLOOK P2P: Point to Point, 点对点,两点之间是平等的地位,功能完全相同:而C/S, B/S, 各端只能做各自的事

面向服务的体系架构(SOA)—架构篇

面向服务的体系架构(SOA)-架构篇 1.面向服务的体系架构(SOA) 面向服务的架构(service-oriented architecture)是Gartner于2O世纪9O年代中期提出的面向服务架构的概念.2002年的l2月,Gartner提出"面向服务的架构(SOA)"是"现代应用开发领域最重要的课题"之后.国内外计算机专家.学者掀起了对SOA的积极研究与探索. 在分布式的环境中,将各种功能都以服务的形式提供给最终用户或者其他服务.如今,企业级应用的开发都采

软件体系架构课下作业06

题目:对上学期学习的软件设计模式进行复习,对所有设计模式进行分析,用自己的话来阐述对他们的理解.(不少于2000字) 正如本学期所学习的软件体系架构,还有很多其他的软件工程技术一样,设计模式同样起源于建筑领域他是对前人经验的总结,为后人设计与开发基于面向对象的软件提供指导方针和成熟的解决方案. 从模式的目的而言,设计模式可以分为创建型.结构型和行为型三种.创建型模式主要用于创建对象,它包含5种模式,分别是:工厂方法模式.抽象工厂模式.建造者模式.原型模式和单例模式:结构型模式主要用于处理类和对象

DBA_Oracle基本体系架构(概念)

DBA_Oracle基本体系架构(概念) 2014-07-26 BaoXinjian 一. Oracle体系结构基本概念 1. Oracle总体结构分为三个部分 第一部分:系统全局区(SGA) 第二部分:程序全局区和后台进程 第三部分:Oracle的文件 2. 从功能角度接那些划分 存储结构 包括: 控制文件.数据文件和日志文件 作用: 由这些文件就构成了Oracle的物理存储结构. 内存结构 包括: 系统全局区(SGA) 和 程序全局区(PGA) 作用: 使用内存最多的是SGA,也是影响数据库

Hive基础之Hive体系架构&amp;运行模式&amp;Hive与关系型数据的区别

Hive架构 1)用户接口: CLI(hive shell):命令行工具:启动方式:hive 或者 hive --service cli ThriftServer:通过Thrift对外提供服务,默认端口是10000:启动方式:hive --service hiveserver WEBUI(浏览器访问hive):通过浏览器访问hive,默认端口是9999:启动方式:hive --service hwi 2)元数据存储(Metastore):启动方式:hive -service metastore

InnoDb 体系架构和特性 (Innodb存储引擎读书笔记)

后台线程 Master Thread 核心后台线程,主要负责将缓冲池的数据异步刷新到磁盘.例如脏页的刷新,插入缓冲的合并,undo 页的回收等. 每秒一次的操作: 日志缓冲刷新到磁盘,即使该事务还没有提交.该操作总是会发生,这个就是为了再大的事务,提交时间都很短. 当IO压力很小时(1s内发生的IO次数小于5% innodb_io_capacity)合并5% innodb_io_capacity 的插入缓冲. 当脏页比例大于 innodb_max_dirty_pages_cnt, 刷新 inno