Tomcat的顶层结构
tomcat中最顶层的容器叫Server,代表整个服务器,Server中包含至少一个Service,用于具体提供服务。Service主要包含两个部分:Connector和Container。Connector用于处理连接相关的事情,并提供Socket与request,response的转换,Container用于封装和管理Servlet,以及具体处理request请求。一个Tomcat中只有一个Server,一个Server可以包含多个Service,一个Service只有一个Container,但可以有多个Connectors(因为一个服务可以有多个连接,如同时提供http和https连接,也可以提供相关协议不同端口的连接)。
Tomcat里的Server由org.apache.catalian.startup.Catalina来管理,Catalina是整个Toncat的管理类,它里面的三个方法load,start,stop分别用来管理整个服务器的生命周期,load方法用于根据conf/server.xml文件创建Server并调用Server的init方法进行初始化,start方法用于启动服务器,stop方法用于停止服务器,start和stop方法在内部分别调用了Server的start和stop方法,load方法在内部调用了Server的init方法,这三个方法都会按容器的结构逐层调用相应的方法,比如,Server的start方法中会调用所有的Service中的start方法,Service中的start方法又会调用所有包含的Connectors和Container的start方法,这样整个服务器就启动了,init和stop方法也一样,这就是整个Tomcat生命周期的管理方式。Catalina还有个方法也很重要,那就是await方法,Catalina中的await方法直接调用了Server的await方法,这个方法的作用是进入一个循环,让主线程不会退出。
不过Tomcat的入口main方法并不在Catalina类中,而是在org.apache.catalina.startup.Bootstrap中。Bootstrap的作用类似一个CatalinaAdaptor,具体处理过程还是使用Catalina来完成的,这么做的好处是把可以启动的入口和具体的管理类分开,从而可以很方便的创建出多种启动方式,每种启动方式只需要写一个相应的CatalinaAdaptor就可以了。