Tomcat主要通过Acceptor和Poller来接收请求。
【Acceptor】
主要负责socket的accept事件. 而且默认情况下采用的是阻塞式.
采用阻塞式循环等待客户端请求,将接收到的请求包装一下,然后放入Poller的同步队列events中.
【Poller】
主要负责check selecor是否准备好read/write,如果准备好了则将该channel包装包装丢给线程池去处理.
1. Poller与selector一一对应
2. Poller循环查看selector中是否有socketchannel处于就绪状态?
-2.1 如果存在则将其丢给线程池,使用容器去处理具体请求
-2.2 如果不存在则查看events中是否有新的请求?
--2.2.1如果存在新的socketchannel则让其OP_READ注册至Poller中的selector
3. Poller循环遍历检测selecor中的socketchannel是否已经超时?一般在20s
-3.1 如果超时则关闭该socketchannel并从selector中移除,下次客户端来的请求将会新建socketchannel
-3.2 如果没有超时则该socketchannel保持,在没有超时期间来的请求会重用该socketchannel。一次网页打开有大量请求时,有些请求会用上同一个socketchannel。