Tomcat启动加载过程

     我 是在看jvm类加载机制时突然想到我们经常使用的tomcat是如何启动?如何加载类的?于是顺藤摸瓜找了找,和大家分享下,比较粗糙,不要介意。

1、start.bat是启动tomcat的脚本,查看脚本可知其实是启动catalina.bat。

2、在catalina.bat中可以看到执行setclasspath.bat,setclasspath.bat是做一些变量参数设置,比如这里可以设置JVM的内存。

3、在catalina.bat最重要的启动入口:

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS% -Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath "%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%" -Dcatalina.home="%CATALINA_HOME%" -Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS% %ACTION%

在catalina.bat看到CLASSPATH=%CLASSPATH%%CATALINA_HOME%\bin\bootstrap.jar和MAINCLASS=org.apache.catalina.startup.Bootstrap,就知道bootstrap.jar包中的main方法是tomcat的主入口。

4、通过反编译我们可以看到如图:



这里有三个类加载器,主要使用commonLoader去加载tomcat的核心包,在catalina.properties中可以看到如下配置:

common.loader=${catalina.base}/lib,${catalina.base}/lib/*.jar,${catalina.home}/lib,${catalina.home}/lib/*.jar

这些核心包中又有类加载器去加载我们的项目,这里我就没有继续追下去了,但是我想肯定与经常配置的server.xml有关,比如下面的配置:

 <Host name="localhost"  appBase="webapps" unpackWARs="true" autoDeploy="true">
	<Valve className="org.apache.catalina.valves.AccessLogValve" directory="logs"
               prefix="localhost_access_log." suffix=".txt"
               pattern="%h %l %u %t "%r" %s %b" />
	<Context  path="/bcp"  docBase="D:\dist\WebContent" antiResourceLocking="false" privileged="false" reloadable="true"/>
 </Host>




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值