上节说到接收器Acceptor在接收到socket后会有一系列简单的处理,其中将socket扔进线程池是最重要的一步,线程池是一个怎样东西?其原理在前面的“线程池原理”章节已经说明过了,这里重点讲tomcat中用于处理客户端请求的线程池——Executor。
为确保整个web服务器的性能,应该在接到请求后以最快的速度转交到其他线程上去处理。在接收到客户端的请求后tomcat将对这些请求交给任务执行器Executor,它是一个拥有最大最小线程数限制的线程池,之所以称之为“任务执行器”是因为线程池可以看做是启动了若干线程不断检测某个任务队列,一旦发现有需要执行的任务则执行。如下图,每条线程都不断循环检测任务队列,数量不会少于最小线程数也不能大于最大线程数。
任务执行器的具体实现是使用juc工具包的ThreadPoolExecutor类,它提供了拥有多种机制的线程池,例如有最大最小线程数限制、多余线程回收时间限制、超出最大线程数时线程池做出的拒绝动作等等。继承此类并重写一些方法基本就能满足tomcat个性化需求。