tomcat源码阅读之默认连接器
默认连接器
一、UML图:
1、所有的连接器都要实现Connector接口,必须创建Request对象和Response对象,httpConnector作为默认连接器,肯定也是要实现Connector接口的,同时httpConnector. createRequest方法创建了Request对象,httpConnector. createResponse方法创建了Response对象;
2、httpConnector接收到客户端请求后,解析请求参数、解析请求header信息、创建Response和Request对象如果放在Connector里面处理,势必会影响到后续其他客户端请求的及时响应,因此tomcat采取了HttpProcessor对象来进行这些后续处理,而且HttpProcessor是在单独的线程里面运行,不会卡住主线程,再有新的客户端请求到达时,会创建新的HttpProcessor对象并开启新的线程运行,这样就能保证连接器能高效及时的响应客户端请求;
3、httpConnector类维护着一个HttpProcessor的实例池,同时还有池的最小和最大个数的变量,如下:
在start方法启动连接器时,会初始化minProcessors个HttpProcessor对象放到processors池子里面:
创建HttpProcessor对象时,如果池子里有未使用的HttpProcessor对象,则直接从池子里面取,如果当前正在运行的HttpProcessor对象大于最大个数,则丢掉请求不处理,否则创建一个HttpProcessor对象并放到池子里,然后返回这个HttpProcessor对象:
1、Request对象封装了客户端的请求信息,Response对象封装了返回给客户端的响应信息;
2、HttpRequestImpl类是Request接口的实现类,cookies数组成员变量存储了请求的cookie信息,headers变量是一个hashMap类型,存储了请求head信息的键值对,parameters存储了相关参数的键值对,这是一个ParameterMap类型的hash表类型,比hashMap封装扩展了锁定属性;
3、为避免servlet程序员拿到request对象,因为权限过大而造成安全问题,这里采用了门面模式封装了一个HttpRequestFacade对象,其所有功能都委托给Request对象实现,但是HttpRequestFacade提供的接口有限,将其提供给servlet程序员不会造成安全问题;
4、同样的,HttpResponseImpl类是Response接口的实现类,HttpResponseFacade作为HttpResponseImpl的门面对象提供给servlet程序员使用,从而很好的解决了安全性问题;
二、流程分析:
1、httpConnector连接器实现了Runnable接口,也就是说他是运行在一个线程里面的,run方法作为线程的运行方法,首先调用ServerSocketFactory.createSocket创建一个ServerSocket对象,并且默认在8080端口上监听,然后调用ServerSocket.accept在8080端口等待客户端请求并阻塞线程;
2、如果有客户端连接请求到达,则httpConnector从accept处返回,然后调用CreateHttpProcessor创建HttpProcessor对象;
3、在创建HttpProcessor对象时,在HttpProcessor构造函数里面创建HttpRequest对象和HttpResponse对象;
4、httpConnector在调用CreateHttpProcessor后,会将服务器与客户端连接的socket对象赋值给HttpProcessor对象,然后调用HttpProcessor.start方法,由于HttpProcessor也实现了Runnable接口,因此在start方法里面就将HttpProcessor放到线程里运行;
5、HttpProcessor线程的run方法里面,首先获取刚才赋值的socket对象(如果socket为null则会阻塞到socket被赋值),然后对request请求调用parseConnection, parseRequest, parseHeaders解析请求信息并设置request的成员变量;
6、最后将request和response对象传递给Container.invoke方法,将后续的请求处理交给Container容器处理;
tomcat源码阅读之默认连接器的更多相关文章
- Tomcat源码阅读(二)初始化
近来,我开始阅读tomcat的源码,感觉还挺清晰易懂:为了方便理解,我参考了网上的一些文章,把tomcat的组成归纳一下:整个tomcat的组成如下图所示: Tomcat在接收到用户请求时,将会通过以 ...
- tomcat源码阅读之载入器(Loader)
一.Java类的载入器: 双亲委派模型: 1.JVM提供了三种类型的类加载器:引导类载入器(bootstrap class loader).扩展类载入器(extension class loader) ...
- tomcat源码阅读
1 工具准备 需要SVN.Maven.JDK.Eclipse.Eclipse M2插件 2 下载源码及发布包 源码在这里:http://svn.apache.org/repos/a ...
- tomcat源码阅读之过滤器
一.Servlet过滤器: 1.介绍: Servlet过滤器本身并不生成请求和响应对象,它只提供过滤作用. Servlet过滤器能够在Servlet被调用之前检查Request对象,修改Request ...
- tomcat源码阅读之SingleThreadModel
一.接口简介: 实现了SingleThreadModel接口的servlet类只能保证在同一时刻,只有一个线程执行该servlet实例的service方法,在tomcat实现中会创建多个servlet ...
- tomcat源码阅读之BackupManager
一. 配置: <Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOpti ...
- tomcat源码阅读之Server和Service接口解析
tomcat中的服务器组件接口是Server接口,服务接口是Service,Server接口表示Catalina的整个servlet引擎,囊括了所有的组件,提供了一种优雅的方式来启动/关闭Catali ...
- tomcat源码阅读之安全机制
一.领域(Realm): 1.Principal接口代表角色信息,包含了三个成员:用户名.密码.role列表(以逗号分隔),对应了tomcat-users.xml文件中一行user信息: Generi ...
- tomcat源码阅读之集群
一. 配置: 在tomcat目录下的conf/Server.xml配置文件中增加如下配置: <!-- Cluster(集群,族) 节点,如果你要配置tomcat集群,则需要使用此节点. clas ...
随机推荐
- 记录搭建ssm项目
搞java也快3年了,搭建一个ssm居然有点吃力. 参考链接:https://blog.csdn.net/gebitan505/article/details/44455235/ 环境准备:jdk8. ...
- freemarker中的null异常处理以及!与??的使用(转)
原文链接: https://blog.csdn.net/mexican_jacky/article/details/50638062 阅读数:6304 如工程包含: 在user中我们有个角色,那么我们 ...
- React-native-camera error with Expo: undefined is not an object (evaluating 'CameraManager.Aspect')
React-native-camera error with Expo: undefined is not an object (evaluating 'CameraManager.Aspect') ...
- 大数据-10-Spark入门之支持向量机SVM分类器
简介 支持向量机SVM是一种二分类模型.它的基本模型是定义在特征空间上的间隔最大的线性分类器.支持向量机学习方法包含3种模型:线性可分支持向量机.线性支持向量机及非线性支持向量机.当训练数据线性可分时 ...
- Python 笔试 —— 效率与优雅
1. 效率 字符串拼接: 加号拼接字符串将造成对象的创建和垃圾的回收: 使用字符串的 join 方法对尤其是循环中的字符串进行拼接(先将不断出现的字符串 append 到 一个 list 中,再进行 ...
- gcc/g++ 使用 tricks
0. 优化级别 -O0,不进行优化的编译后的文件大小反而更小,小于 -O2 的: 1. -std 指定 C 语言标准 -ansi -ansi == -std=c90 -std=c99:(std:sta ...
- Linux 对文件进行加密存放
/********************************************************************** * Linux 对文件进行加密存放 * 说明: * Gi ...
- 【linux基础】V4L2介绍
参考 1. https://www.cnblogs.com/hzhida/archive/2012/05/29/2524351.html 2. https://www.cnblogs.com/hzhi ...
- numpy中的复合数组
1.复合数组的创建 # 复合数组,最重要的是定义dtype a = np.array([('ABC', [1, 2, 3])], dtype="U3, 3i4") print(a) ...
- PAT-1084(外观数列 ) && PAT-1085 (PAT单位排行)
1084 利用字符串string的可加性 #include <bits/stdc++.h> using namespace std; int main () { int x,n; cin ...