第11章 Tomcat的系统架构与设计模式
11.1 Tomcat总体设计
11.1.1 Tomcat总体架构
Tomcat和核心有连个组件:Connector和Container,Connector是可以被替换的。一个container可以有多个connector,多个connector和一个container形成一个service,service的生存环境就是server。所以Tomcat的声明周期由Server控制。
1. 以Service作为“婚姻”
Connector负责对外交流,container主要处理connector接受的请求,主要处理内部事务。Service将两者组合到一起。Service只是在Connector和Container外面包一层,向外提供服务。一个Service可以设置多个Connector,但是只能有一个Connector容器。
Tomcat中service接口的标准实现类是StandardService,它不仅实现了Service接口,同时实现了Lifecycle接口。
2. 以Server为“居”
提供接口让其他程序能访问这个Service集合,同时维护它包含的所有Service生命周期,包括如何初始化,如何结束服务 如何找别人要访问的service。
server的标准实现类StandardServer实现了先关方法。
3. 组件的生命“Lifecycle”
Tomcat中组件的生命周期通过Lifecycle接口控制,组件只要继承这个接口,并实现其中的方法就可以统一被拥有它的组件控制了。这样一层一层的,直到最高级的组件就可以控制Tomcat中酥油组件的生命周期了,这个最高组件就是Server,而控制server的是StartUP,也就是启动和关闭Tomcat
Server启动时,下面的services都启动;stop时,所有的services都stop
11.1.2 Connector组件
Connector组件是Tomcat中的两个核心组件之一。主要任务是负责监听浏览器发过来的TCP连接请求,创建一个Request和Response对象分别用于和请求端交换数据。然后会产生一个线程来处理这个请求并把产生的Request和Response对象传递给处理这个请求的线程。处理这个请求的线程就是Container组件要做的事了。
当Connector将Socket连接封装成Request和Respone对象后,接下来的事交给Container来处理。
11.1.3 Servlet容器Container
Container是容器的父接口,所有的子容器都必须实现这个接口,Container容器的设计用的是典型的责任链的设计模式,它由4个子容器组件构成,分别是Engine, Host, Context和Wrapper,这4个组件不是平行的,而是父子关系,Engine包含Host,Host包含Context,Context包含Wrapper。通常是一个Servlet class对应一个Wrapper,如果多个Servlet可以定义多个Wrapper;如果有多个Wrapper,则要定义一个更高级别的Container,如Context,Context通常对应下面的配置:
<Context path="/library" docBase="D:/proects\library\deploy\target\library.war" reloadable=true>
1. 容器的总体设计
Context还可以定义在父容器Host中,Host不是必须的,但是要运行war程序,就必须用Host,因为在war中必有web.xml文件,这个文件的解析需要Host。如果有多个HOSt,就需要定义Engine了。Engine就是一个完整的Servlet引擎。
2. Engine容器
标准实现类是StandardEngine,添加子容器只能是Host类型。
3. Host容器
Host是engine的子容器,一个Host代码一个虚拟主机,这个主机的作用就是运行多个应用,它负责安装和展开这些应用,
4. Context容器
Context代表Servlet的Context,它具备了Servlet运行的基本环境,理论上只要要Context就可以运行Servlet了,简单的Tomcat可以没有Engine和Host。
Context最重要的功能是管理它里面的Servlet实例,Servlet实例在Context中是以Wrapper出现的。
Context的配置文件有个reloadable属性,为true时,war被修改后Tomcat会自动重新加载这个应用。
5. Wrapper容器
Wrapper代表一个Servlet,它负责管理一个Servlet,包括Servlet的装载、初始化、执行及资源回收。
实现类是StandardWrapper,还实现了一个Servlet初始化信息的ServletConfig。
它基本描述了对Servlet的操作,装载了Servlet后就会调用Servlet的init方法。
当Servlet被初始化完成后,就等着StandardWrapperValue去调用它的service方法了,调用Service方法之前要调用Servlet所有的的filter。
11.1.4 Tomcat中的其他组件
安全组件security, 日志组件logger, session, mbeans,naming等。这些组件共同为Connector和Container提供必要的服务。
11.2 Tomcat中的设计模式
11.2.1 门面设计模式
1. 门面设计模式的原理
2. Tomcat的门面设计模式示例
11.2.2 观察者设计模式
1. 观察者模式的原理
2. Tomcat的观察者模式示例
11.2.3 命令设计模式
1. 命令模式的原理
2. Tomcat中命令模式的示例
11.2.4 责任链设计模式
1. 责任链模式的原理
2. Tomcat中的责任链模式示例
11.3 总结
第11章 Tomcat的系统架构与设计模式的更多相关文章
- 第十一章 Tomcat的系统架构与设计模式(待续)
Tomcat总体设计 Tomcat中的设计模式
- Tomcat 系统架构与设计模式
Tomcat 系统架构与设计模式,第 1 部分: 工作原理 这个分为两个部分的系列文章将研究 Apache Tomcat 的系统架构以及其运用的很多经典设计模式.本文是第 1 部分,将主要从 Tomc ...
- Tomcat 系统架构与设计模式,第 1 部分: 工作原理(转载)
简介: 这个分为两个部分的系列文章将研究 Apache Tomcat 的系统架构以及其运用的很多经典设计模式.本文是第 1 部分,将主要从 Tomcat 如何分发请求.如何处理多用户同时请求,还有它的 ...
- Tomcat 系统架构与设计模式,第 1 部分: 工作原理
简介: 这个分为两个部分的系列文章将研究 Apache Tomcat 的系统架构以及其运用的很多经典设计模式.本文是第 1 部分,将主要从 Tomcat 如何分发请求.如何处理多用户同时请求,还有它的 ...
- tomcat 系统架构与设计模式 第一部分 系统架构工作原理 转
Tomcat 系统架构与设计模式,第 1 部分: 工作原理 许 令波, Java 开发工程师, 淘宝网 许令波,现就职于淘宝网,是一名 Java 开发工程师.对大型互联网架构设计颇感兴趣,并对一些开源 ...
- 【Tomcat】Tomcat 系统架构与设计模式,第 1 部分: 工作原理
这个分为两个部分的系列文章将研究 Apache Tomcat 的系统架构以及其运用的很多经典设计模式.本文是第 1 部分,将主要从 Tomcat 如何分发请求.如何处理多用户同时请求,还有它的多级容器 ...
- Tomcat 系统架构与设计模式之一
Tomcat 系统架构与设计模式,第 1 部分: 工作原理 来自:http://www.ibm.com/developerworks/cn/java/j-lo-tomcat1/index.html 这 ...
- tomcat 系统架构与设计模式 第二部分 设计模式 转
Tomcat 系统架构与设计模式,第 2 部分: 设计模式分析 许 令波, Java 开发工程师, 淘宝网 许令波,现就职于淘宝网,是一名 Java 开发工程师.对大型互联网架构设计颇感兴趣,并对一些 ...
- Tomcat 系统架构与设计模式之二
Tomcat 系统架构与设计模式,第 2 部分: 设计模式分析 来自:http://www.ibm.com/developerworks/cn/java/j-lo-tomcat2/ 这个分为两个部分的 ...
随机推荐
- mysql中删除完全重复数据的准确SQL语句
删除数据库中重复的记录,只保留一条 DELETE FROM tb_gps_records WHERE id NOT IN (SELECT bid FROM (SELECT min(id) as bid ...
- MySql的数据库文件
找到mysql安装目录下的一个叫my.ini的文件用记事本或者其他的文本编辑器打开. 找到datadir这个字段,这个地址就是mysql数据库的地址 另附my.ini详解 Mysql my.ini 配 ...
- git回滚到某一个commit
git reset 046bd7b5c1d134b8123f59ea71b19875a6a2fc3e git reset --hard 046bd7b5c1d134b8123f59ea71b19875 ...
- Pro C/C++环境搭建
一. 安装oracle软件或者oracle客户端. 二. 载入orasql10.lib (1)在连接器->常规->附件库目录中,加入orasql10.lib库所在目录. (2)在连接器-& ...
- cassandra压力测试
http://docs.datastax.com/en/archived/cassandra/2.2/cassandra/tools/toolsCStress.html?hl=stress Simpl ...
- Android移动端网络优化
介绍下针对移动端的网络优化,不限于 Android,同样适用于 iOS 和 H5 本文为性能优化系列第四篇,目前性能调优专题已完成以下部分: 性能优化总纲——性能问题及性能调优方式 性能优化第四篇—— ...
- Django常用插件
1 富文本编辑器--tinymce 2 分页器--pure pagination 视图中 all_orgs_list = CourseOrg.objects.all() try: page = req ...
- Redis 补充
Redis 补充 Redis 的主要用途 数据库 缓存和消息中间件 相当于一个字典 数据库切换 select 1 (默认36个数据库 默认在0) 1 基本数据类型 字符串 散列 hashes 列表 集 ...
- POSIX线程同步
在posix编程中,如果在不同的线程中几乎同一时间操作同一个变量的时候,就会出现不同步. 如何解决这样的问题,这里需要用到互斥量,互斥锁的概念.请看UNIX环境高级编程P299页 #include & ...
- linux 权限之所有者所属组
linux 如何改变文件属性与权限 我们知道档案权限对于一个系统的安全重要性,也知道档案的权限对于使用者与群组的相关性, 那如何修改一个档案的属性与权限呢? 我们这里介绍几个常用于群组.拥有者.各种身 ...