解析EndPoint调用过程:
我们已知整个tomcat组件都是通过LifeCycle接口下的LifeCycleBase模版方法init调用initInternal完成初始化,调用start方法运行。
- LifeCycle
-
LifeCycleBase -
tomcat组件
那么EndPoint也不例外,不过EndPoint是通过Protocolhandler进行初始化的。
Protocolhandler则是通过Connector进行初始化。
其中Connector才继承了LifeCycleBase类。
那么我们直接在Connector类下找到initInternal方法,重要操作一般都在try中。
try {
protocolHandler.init();
} catch (Exception e) {
throw new LifecycleException(
sm.getString("coyoteConnector.protocolHandlerInitializationFailed"), e);
}
ProtocolHandler是一个协议处理器。
Tomcat支持NIO NIO2(异步) Apr这三种IO模型,支持HTTP1.1 AJP等应用层协议。
IO在传输层中,协议在应用层中,所以两两组合,最起码都有6种。
AbstractProtocol作为抽象类实现ProtocolHandler接口,使用组合的方式,其内部成员变量有一个AbstractEndpoint封装EndPoint。

ProtocolHandler中有EndPoint和Processor。
我们找到一个最常用的ProtocolHandler:Http11NioProtocol
public Http11NioProtocol() {
super(new NioEndpoint());
}
其构造方法调用父类的构造方法注入NioEndpoint。
NioEndpoint重要的有三个东西:
1.Acceptor[] acceptors
2.Poller[] pollers
3.PollerEvent
其中1,2都相当于一个线程数组
在调用Connector的start方法时,往下会调用EndPoint的start方法,那么这时就会创建线程start。
先开启pollers数组线程
再开启acceptors数组线程
我们可以分别查看两个类的run方法:
Poller:
以下是Poller的run方法
public void run() {
// Loop until destroy() is called
while (true) {
boolean hasEvents = false;
try {
if (!close) {
hasEvents = events();
if (wakeupCounter.getAndSet(-1) > 0) {

本文深入解析了Tomcat中Endpoint的初始化过程,涉及LifeCycle接口、ProtocolHandler和Connector的角色。Endpoint通过ProtocolHandler初始化,而ProtocolHandler由Connector管理,Connector继承LifeCycleBase并调用initInternal方法。在启动时,首先启动Poller线程,接着启动Acceptor线程。Acceptor接收客户端请求,Poller则负责处理事件。整个流程确保了Tomcat对HTTP请求的有效处理和响应。
最低0.47元/天 解锁文章
1万+

被折叠的 条评论
为什么被折叠?



