java web工程师而言常用的web容器tomcat,jetty都是工作中经常被用到的。通常我们只会记得它是怎么用的,至于它是干什么的,很难说清楚,只知道它是个web容器。因为我们开发的工作更多是在应用层框架(比如spring mvc)内部填写业务代码,至于TCP层到HTTP层可能很少关心。但凡一个完整的基于HTTP协议的java应用,都需要考虑如下几点:
1.数据是怎么从TCP层的字节数组转为HTTP层的请求对象
2.HTTP请求对象怎样合理被调度(即线程模型)
3.被调度的请求应该走什么样的业务逻辑
第1点考虑更多的是编解码加解密,第2点则是http请求该如何提交给线程池去处理,第3点其实就是我们经常接触到的web框架,spring mvc,ssh等等。
第1和第2点我们可以去实现,大公司内部经常会自己去写一套这种框架。web容器也实现了第1和第2点,同时它还必须遵循javax.servlet中api接口协议(即我们经常引用到的javax.servlet-api.jar)。
tomcat作为web容器一个典型代表,分析它的代码,对我们设计自己的框架能提供一些借鉴。分析tomcat的源码,建议可以用嵌入式的tomcat去逐步调试查看,结合独立tomcat中的server.xml文件理解。
来看一张层次图:
在tomcat中各模块以组件的形式存在,并通过实现接口Lifecycle,管理组件的生命周期。大致的关系图如下:
tomcat内部主要由Connector连接器和Container容器两部分组成。
Connector主要负责如何处理IO,NIO(非阻塞式)还是BIO(阻塞式)。
参考文档: http://www.365mini.com/page/tomcat-connector-mode.htm
Container主要负责接收来自Connector的请求,并按照容器的顺序挨个转发给相应的容器,最后的容器处理完请求后响应输出。