Tomcat线程分析

用一般配置下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)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值