Tomcat 源码阅读(三)Catalina.start

来源:互联网 发布:ubuntu ntp server 编辑:程序博客网 时间:2024/06/08 20:03

环境: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方法。