javaWeb开发的童鞋,经常跟tomcat等接触,当然apache还有jetty这种轻量级容器;至于jboss、weblogic啥的,现在还没怎么玩过。
web应用要,对外提供http服务,童鞋们把他部署到servlet容器(暂不讨论微服务啥的),由servlet容器运行web应用,来张tomcat的图:
层次感很强、一个个组件,tomcat架构给人的感觉,来分别说说这些哥们:
Connector:负责网络IO,有BIO、NIO、NIO2、AIO,实际部署使用apache(或者nginx)转发;
Container:对应概念模型中的引擎、主机、应用、Servlet,容器处理通过Pipeline管道,由不同的Valve处理,类似责任链模式;
再来说说容器的运行,以nio就是http11Protocol为例,endpoint搞到一个连接socket,从threadPoolExecutor喊来一个socketHandler,就是请求的处理者,通过processor对象池,调用adapter进入Container;
然后, container就开始父子逐级调用,通过pipeline管道,由vavle来做逻辑处理,直到返回到processor;
最后,根据socket的状态,判断返回、继续等等,表示没理解全,状态不少的说。
那个,平时我们做网络开发,用netty就好了,不必自己处理网络IO,下面,木有了。