一个良好甚至优秀的系统,架构上一定要做到可伸缩性和可扩展性,Tomcat在这个方面是个非常好的榜样,它还保证了每个组件的灵活性,最大程度提高了组件的可扩展性。
为了增强组件的灵活性和可扩展性,Tomcat采用了职责链模式来实现客户端请求的处理,Tomcat中每个Container组件都是通过执行一个职责链来完成具体的请求处理。为此,Tomcat定义了Pipeline(管道)和Valve(阀)两个接口抽象,前者用来构建职责链,后者代表了一个职责链上的一个处理器。用个形象的比喻来说,来自客户端的请求就如同流经自来水管的水,经过每个阀门进行处理,设计如下:
Pipeline中维护了一个最基础的Valve ,它始终位于Pipeline的最末端,代表了它始终最最后的处理,封装了具体的请求处理和输出响应的过程