博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Tomcat源码分析(一)
阅读量:6073 次
发布时间:2019-06-20

本文共 1708 字,大约阅读时间需要 5 分钟。

这段时间简单的看了一下Tomcat的源码,在这里做个笔记!

  1. tomcat 架构图

 

Catalina: tomcat的顶级容器,main()方法中就是通过,创建Catalina 对象实例,来启动或者关闭 tomcat;

Server: 是管理tomcat所有组件的容器,包含一个或多个的service;

Service: Service是包含Connector和Container的集合,Service用适当的Connector接收用户的请求,再发给相应的Container来处理;

Connector: 主要功能是 ◇socket的接收 ◇根据协议类型处理socket ◇封装相应的request和response,交给Container;

Container: Engine容器接收来自Connector的请求,并且通过Pipeline依次传递给子容器的Pipeline;

Engine: 在Engine的Pipeline中的Valve的invoke方法中,根据request.getHost()来定位下一个host;

Host: 一个Web服务器虚拟机,管理着具体的 web application;

Context: 就是我们所部属的具体Web应用的上下文,每个请求都是在具体的上下文中处理;

Wrapper:对应着Web的每一个 Servlet;

接下来,主要学习tomcat中的两个最主要的容器,Connector和Container容器。

 

  2. Connector容器

Connector容器主要解决的问题就是Socket的接收,为了能够很好的处理各种协议和并发异步接收,Connector加入了两个组件 ProtocolHandler和EndPoint。

ProtocolHandler的主要作用就是根据各个协议的定义按照一定的格式句分析协议头,封装成request和response对象;

AbstractEndPoint 致力于高并发的解决socket的接收和处理;

 

2.1 AbstractEndPoint

EndPoint 中两个协同合作的Runnable:

(1) Accepter负责用ServerSocket.accept()来接收客户请求,并且把建立连接之后的Socket交由Poller处理;

(2) Poller负责接收请求,并处理;

protected class Acceptor extends AbstractEndpoint.Acceptor (Acceptor implements Runnable)public class Poller implements Runnable

 Accepter和Poller的具体写作示意图(个人拙见)

 从上图中,我们可以发现,Acceptor接收到一个用户的socket请求之后,将这个Socket封装成PollerEvent,放入events队列中。Poller实际上,一直while(true),当执行events队列中有PollerEvent的时候,就会从自己的Selector中获取到一个有数据的Channel,交给ProcessKey()处理。

 

2.1 ProtocolHandler

每一种协议都有各自具体定义,和具体的协议头的格式,那么我么在接收到客户请求之后,就应该根据协议的类型采用相应的解析方法。

ProtocolHandler的具体作用:

◆ 定义具体处理Socket的AbstractEndPoint;

◆ 提供解析请求的AbstractConnectionHandler来获取具体的协议头;

◆ 相关的init、start、stop方法

 

【参考文献】

[1] http://blog.csdn.net/cutesource/article/details/5006062

[2] http://blog.csdn.net/yanlinwang/article/details/45648039

转载于:https://www.cnblogs.com/felixpan/p/4910584.html

你可能感兴趣的文章
epoll的lt和et模式的实验
查看>>
Flux OOM实例
查看>>
07-k8s-dns
查看>>
Android 中 ListView 分页加载数据
查看>>
oracle启动报错:ORA-00845: MEMORY_TARGET not supported on this system
查看>>
Go方法
查看>>
Dapper丶DapperExtention,以及AbpDapper之间的关系,
查看>>
搞IT的同学们,你们在哪个等级__那些年发过的帖子
查看>>
且谈语音搜索
查看>>
MySQL数据库导入导出常用命令
查看>>
低版本Samba无法挂载
查看>>
Telegraf+Influxdb+Grafana构建监控平台
查看>>
使用excel 展现数据库内容
查看>>
C#方法拓展
查看>>
MySql.Data.dll的版本
查看>>
Linux系统磁盘管理
查看>>
hdu 2191 (多重背包+二进制优化)
查看>>
PHP中替换换行符
查看>>
Android之更新ListView,位置置顶的问题
查看>>
stl-基本知识
查看>>