tomcat 那些事

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 那些事_第1张图片

在tomcat中各模块以组件的形式存在,并通过实现接口Lifecycle,管理组件的生命周期。大致的关系图如下:

tomcat 那些事_第2张图片

tomcat内部主要由Connector连接器和Container容器两部分组成。

Connector主要负责如何处理IO,NIO(非阻塞式)还是BIO(阻塞式)。

参考文档: http://www.365mini.com/page/tomcat-connector-mode.htm

Container主要负责接收来自Connector的请求,并按照容器的顺序挨个转发给相应的容器,最后的容器处理完请求后响应输出。



你可能感兴趣的:(tomcat)