Tomcat的技术内幕和在喜马拉雅的实践
1. IO Thread Model
Tomcat是一个非常完整、完善、功能非常强大的开源项目。我们每个人开始做开发,接触的第一个项目可能就是Tomcat。我们今天主要介绍的就是IO和线程模型,IO包括NIO和NIO2。
上图是NIO的线程模型,它负责接收连接。Tomcat创建一个端口,然后我们接受浏览器发起的请求,accept线程是block,有连接就连接,没有连接就等待新的连接请求。
它接收连接之后,会创建一些Socket,然后把这些Socket放到EventQueue里,通过Poller线程消费EventQueue里的Socket,注册到Selector上。Poller线程负责Selector循环,确认上面是否有读/写事件,如果有读/写事件发生,就生产一个SocketProcessor,提交到Catalina work thread pool。
Poller线程负责将读取事件注册到Selector,创建SocketProcessor提交到Catalina线程池里,从Selector注销读取事件。有一个读事件过来了,它要提交到SocketProcessor真正去处理这个请求。但是Poller线程不负责读,它只做事件触发机制。即告诉你一个事件请求过来了,你可以开始读了。
然后它要把这个事件unregister掉,因为一个请求需要保证只有一个Catalina work线程处理,否则就又会创建一个Socket交给另外一个线程处理。所以在Catalina work线程处理的时候,一定不能有另外一个线程去读Socket的数据,否则包就会乱掉,所以就会有unregister这个操作。
刚刚讲了Poller线程只是告诉你有读事件可以读了,具体的IO的操作还是由Catalina work线程处理。具体的操作包括解析请求行没有阻塞、解析头无阻塞、过滤器路由器、servlet路由器、读body阻塞。
带你读《Apache Tomcat的云原生演进》——Tomcat的技术内幕和在喜马拉雅的实践(2)https://developer.aliyun.com/article/1377542