环境:tomcat7.0.28
坚持一下,把源码看完,勤奋一点,不要在懒惰了,你已经落下别人很多了
本文主要大体介绍Catalina的start方法。
一、总体流程
二、代码解析
1、在Catalina中调用start方法,首先是调用Server的start方法,根据前文可以知道Catalina中的Server实例是StandardServer的对象,并且StandardServer的父类LifecycleBase已经实现了start方法,在LifecycleBase的start 又调用了抽象方法startInternal,所以最终调用的是StandardServer的startInternal方法。
2、在StandardServer的startInternal方法中,调用了Service的start方法,根据代码追踪,最终确定是调用的StandardService的startInternal方法
3、在StandardService的startInternal方法中,代码如下:
protected void startInternal() throws LifecycleException {
if(log.isInfoEnabled())
log.info(sm.getString("standardService.start.name", this.name));
setState(LifecycleState.STARTING);
// Start our defined Container first
if (container != null) {
synchronized (container) {
container.start();
}
}
synchronized (executors) {
for (Executor executor: executors) {
executor.start();
}
}
// Start our defined Connectors second
synchronized (connectorsLock) {
for (Connector connector: connectors) {
try {
// If it has already failed, don't try and start it
if (connector.getState() != LifecycleState.FAILED) {
connector.start();
}
} catch (Exception e) {
log.error(sm.getString(
"standardService.connector.startFailed",
connector), e);
}
}
}
}
通过上面的代码不难看出,在该方法中,首先调用容器Container的start方法,根据前文所述,最终调用的是StandardEngine的startInternal方法。
然后如果在server.xml中配置了Executor,则调用Executor的start方法,最终调用的是StandardThreadExecutor的startInternal方法。
最后调用Connector的start方法。