用一般配置下Tomcat 9线程情况进行分析
main Thread:一般是唯一非daemon线程,await
ContainerBackgroundProcessor:一般只有engine有此线程
Connector一般将协议相关功能委托给自己的ProtocolHandler, ProtocolHandler然后将连接相关委托给内部Endpoint
Connector根据protocol属性决定ProtocolHandler的className,如(HTTP/1.1 AJP/1.3 或者直接指定className,同时考虑是否使用了apr)
Endpoint的start方法一般会启动多个线程,如下面所有线程,注意AsyncTimeout在tomcat9提到ProtocolHandler处了
NioBlockingSelector.BlockPoller-(1,2) :两个Connector,每个的endpoint都有NioSelectorPool-NioBlockingSelector-BlockPoller
http-nio-8080-exec-(1到10):处理线程池:一般core 10,max 200,当然也可以使用Service内定义的Executor(可定义多个,按名称取),将其设置入ProtocolHandler进而设置入Endpoint
http-nio-8080-ClientPoller-(0到1)
http-nio-8080-Acceptor-(0):接收线程,Connector一般提供配置线程个数(Connector有一个setProperty方法,其实现为将属性设置到ProtocolHandler内,ProtocolHandler的setter方法委托到内部endpoint上)
http-nio-8080-AsyncTimeout:tomcat9 移到了ProtocolHandler的start方法开启
同时ajp-nio-8009也有一套同样线程(一般我们有两个Connector)