设为首页 收藏本站
查看: 568|回复: 0

[经验分享] tomcat流程总结

[复制链接]

尚未签到

发表于 2017-1-18 08:33:11 | 显示全部楼层 |阅读模式
  配合着《How tomcat works》一书看看源码,还是很惬意的事情。中途数次想拿起纸笔抑或打开word书写下笔记,但是书中简洁的文风让我觉得没有什么可以记下的。直到最后读完这书,过完源码。才觉得应该记下一些要点来。简单称之为总结吧。
DSC0000.gif

  其实搞懂tomcat或者是类似的servlet的工作原理,只要配合理解这张图就可以了。这就是tomcat的整个工作流程。
  一个HTTP请求到来,其实本质上只是一个输入流,在这个流中蕴含了那些字节代表了这个请求的语义。而图中的1.message就抽象了这个流,把它表示为一条信息。在到达容器的第一时刻,容器是交给connector来处理的。首先这里得考虑一个容器的启动过程,启动时做的一个重要事情就是初始化connector,而connector初始化时干什么呢?显然,创建socket。一切初始化好了,才有第一步消息到来这件事情咯。
  信息到了,connector干的事情就是如图中的2和3步——创建http请求对象和响应对象。当然这个行为也不是connector自己干的,它只是雇佣了一个叫做HttpProcessor的兄弟来干活。真正的creation都是这个兄弟干的。HttpProcessor里面设计了一些简单的并发多线程trick,基本上就是让socket等待着请求信息的到来,来一个,就处理一个。HttpProcessor的一句话总结就是利用多线程技术parse整个请求的stream。几个parse步骤分别是:解析connection;解析request;解析headers。补充一句,request和response对象都是在HttpProcessor初始化的时候初始化的,但是它们内容的填充是在parse的时候完成的。
  接着,connector的任务就结束了。然后一个invoke其实就是工作的交接,该context重磅登场了。Context以其名字就决定了其霸气的侧漏无疑,基本上所有的东西都包含在内。我们把3的invoke当做一些context的自我设置(初始化),那么4的invoke就是context的表演开始了。首先在图里没有给出的是loader和logger的处理,context会在这两个依赖对象不为空的情况下运行它们。Loader是设置java class loader的,tomcat自己定义了一个classloader来加载特定的类。而logger无非就是把日志给启动起来。当然在启动pipeline之前做了启动subcontainer的操作。这是可以理解的,用计算机本质的递归来理解,有点像是先序遍历树的感觉。而pipeline被启动后,后续还有一个manager的启动,这个manager是主要用来管理session的。而所有这些都是可以配置的。
  照着上图主要说说pipeline,pipeline就是流水线了,上面有很多的阀门valve,阀门可以自己加,pipeline的的工作就是步骤5,顺序invoke每个阀门。其实也不是pipeline启动,pipeline其实只是启动了内置的pipelineContext对象,而这个对象会不断的调用invokenext()方法来实现流水线的执行。而这些个valve会调用wrapper,他们的invoke方法会启动wrapper,在检测完mapping后,wrapper会allocate一个servlet实例,接着servlet启动、干活、开始自己的生命周期……这个世界就开始活跃了。
  That is it
  最后奉上一张稍微详细点的图帮助理解。
DSC0001.gif

  当然,美妙的设计这里没有讲,不是因为时间不够或者是空间不足,而是我自己还没有完全的消化,tomcat我认为从设计上讲,结构是beautiful的。光是lifecycle的设计以及各个类模块区分(connector,loader,context,wrapper以及manager等等)之间的初始化调用等细节每个拿出来都够写本书了。So~~~read the fucking source code by yourself。
  参考资料:
  《How tomcat works》
  Tomcat 系统架构与设计模式,第 1 部分: 工作原理http://www.ibm.com/developerworks/cn/java/j-lo-tomcat1/

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-329954-1-1.html 上篇帖子: JMX监控Tomcat 下篇帖子: tomcat基本配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表