tomcat启动(二)org.apache.catalina.startup.Bootstrap分析
/**
* Bootstrap loader for Catalina. This application constructs a class loader
* for use in loading the Catalina internal classes (by accumulating all of the
* JAR files found in the "server" directory under "catalina.home"), and
* starts the regular execution of the container. The purpose of this
* roundabout approach is to keep the Catalina internal classes (and any
* other classes they depend on, such as an XML parser) out of the system
* class path and therefore not visible to application level classes.
这个类构造一个类加载器来加载Catalina内部类(通过在server目录下的catalina.home来找到所有的jar文件),和开始定期执行container容器。
这种回旋处理方法的目的是保持Catalina内部类(以及其依赖的任何其他类,如XML解析器)脱离系统类路径,因此对应用程序级别不可见
入口main方法
在进入main之前会前执行static静态模块代码:主要是设置catalina.home和catalina.base的路径
public static void main(String args[]) {
    bootstrap初始化init()
    设置守护进程daemon = bootstrap;
    识别启动bootstrap时传递的参数command = args[args.length - 1];//start
    daemon.setAwait(true);
    daemon.load(args);
    daemon.start();}
上面damemon守护进程的方法setAwait(),load(),start()其实是反射调用的org.apache.catalina.startup.Catalina类的方法
到这里其实就进入到Catalina类的。
--------------------------Bootstrap类解析完毕------下面是对init方法解释---------------------------------------------------------
初始化init方法(初始化守护进程):
在这个方法里主要流程
1、初始化类加载器initClassLoaders()----------commonLoader,catalinaLoader,sharedLoade会先加载catalina.base/conf/catalina.propertises配置文件
然后读取common.loader键所对应的值
Catalina.properties文件下
common.loader="${catalina.base}/lib","${catalina.base}/lib/*.jar","${catalina.home}/lib","${catalina.home}/lib/*.jar"
补充下:
commonLoader再定义时使用ClassLoader定义,但是创建返回的是URLClassLoader。公有类定义,子类返回,这个思路值得借鉴
public class URLClassLoader extends SecureClassLoader implements Closeable
URLClassLoader继承SecureClassLoader
public class SecureClassLoader extends ClassLoader
SecureClassLoader继承ClassLoader
ClassLoader commonLoader = null;
    ClassLoader catalinaLoader = null;
    ClassLoader sharedLoader = null;
private void initClassLoaders() {
        try {
            commonLoader = createClassLoader("common", null);
            if( commonLoader == null ) {
                // no config file, default to this loader - we might be in a 'single' env.
                commonLoader=this.getClass().getClassLoader();
            }
            catalinaLoader = createClassLoader("server", commonLoader);
            sharedLoader = createClassLoader("shared", commonLoader);
createClassLoader()
获取common.loader键对应的值
String value = CatalinaProperties.getProperty(name + ".loader"); String[] repositoryPaths = getPaths(value);
。。。省略部分代码
for (String repository : repositoryPaths) {
// Check for a JAR URL repository
try {
@SuppressWarnings("unused")
URL url = new URL(repository);
repositories.add(
new Repository(repository, RepositoryType.URL));
continue;
} catch (MalformedURLException e) {
// Ignore
} // Local repository
if (repository.endsWith("*.jar")) {
repository = repository.substring
(0, repository.length() - "*.jar".length());
repositories.add(
new Repository(repository, RepositoryType.GLOB));
} else if (repository.endsWith(".jar")) {
repositories.add(
new Repository(repository, RepositoryType.JAR));
} else {
repositories.add(
new Repository(repository, RepositoryType.DIR));
}
}
return ClassLoaderFactory.createClassLoader(repositories, parent);最后调用这个方法将repositories内存放的类和资源的路径绑定到commonLoader。这里返回的是new URLClassLoader
createClassLoader()方法获取到
common.loader="${catalina.base}/lib","${catalina.base}/lib/*.jar","${catalina.home}/lib","${catalina.home}/lib/*.jar"
接下来会判断这个字符串是以什么结尾
${catalina.base}/lib
${catalina.home}/lib
/lib是目录 commonLoader会加载整个目录下的资源,包括所有clsss、jar包及其它类型资源
${catalina.base}/lib/*.jar
${catalina.home}/lib/*.jar
表示整个目录下所有jar包资源,仅仅是.jar后缀的资源
解释下RepositoryType这是一个枚举类型,定义再类org.apache.catalina.startup.ClassLoaderFactory内部
public static enum RepositoryType {
        DIR,表示整个目录下的资源,包括所有clsss、jar包及其它类型资源。
        GLOB,表示整个目录下所有jar包资源,仅仅是.jar后缀的资源。
        JAR,表示单个jar包资源。
        URL表示网络上得某个jar包资源
    }
2、为当前线程设置classLoader
Thread.currentThread().setContextClassLoader(catalinaLoader);catalinaLoader其实就是commonLoader
用静态类SecurityClassLoad预加载类资源
SecurityClassLoad.securityClassLoad(catalinaLoader);
securityClassLoad(ClassLoader loader, boolean requireSecurityManager)  {   
。。。。。略。。。。。。。。。。
     loadCorePackage(loader);
        loadCoyotePackage(loader);
        loadLoaderPackage(loader);
        loadRealmPackage(loader);
        loadServletsPackage(loader);
        loadSessionPackage(loader);
        loadUtilPackage(loader);
        loadValvesPackage(loader);
        loadWebResourcesPackage(loader);
        loadJavaxPackage(loader);
        loadConnectorPackage(loader);
        loadTomcatPackage(loader);
}
3、初始化org.apache.catalina.startup.Catalina利用反射调用它的setParentClassLoader设置sharedLoader;(设置的parentClassLoader的原因和用处暂不完全清楚,看源码估计会在server.xml加载部分会使用到)
参考资源
Tomcat内核之类加载器工厂
具体源码解析:http://blog.csdn.net/u011545486/article/details/52002626
tomcat启动(二)org.apache.catalina.startup.Bootstrap分析的更多相关文章
- IDEA tomcat启动异常 org.apache.catalina.startup.ContextConfig parseWebXml
		
启动Tomcat发现有异常,总是无法启动,具体的异常日志为下图 具体的解决方法为:在tomcat的conf/content.xml中加上<Loader delegate="true&q ...
 - Tomcat7.0 start Could not find the main class: org.apache.catalina.startup.Bootstrap.
		
java.lang.NoClassDefFoundError: org/apache/juli/logging/LogFactory at org.apache.catalina.startup.Bo ...
 - tomcat启动 报org.apache.catalina.LifecycleException异常
		
java 服务器 tomcat启动 报org.apache.catalina.LifecycleException异常 异常代码如下: [2018-05-10 04:45:08,856] Artifa ...
 - Could not find the main class: org.apache.catalina.startup.Bootstrap.  Program will exit.
		
出现此异常原因是jdk环境变量未配置正确
 - 启动Tomcat服务时,出现org.apache.catalina.startup.VersionLoggerListener报错
		
启动Tomcat服务时,出现org.apache.catalina.startup.VersionLoggerListener报错解决办法:打开Tomcat安装后目录,进入conf文件夹,找到配置文件 ...
 - MyEclipse启动Tomcat报错:Could not find the main class: org.apache.catalina.startup
		
问题描述 Could not find the main class:org.apache.catalina.startup.Bootstrap. Program will exit 问题原因 主要原 ...
 - 现网环境业务不影响,但是tomcat启动一直有error日志,ERROR org.apache.catalina.startup.ContextConfig- Unable to process Jar entry [module-info.class] from Jar [jar:file:/home/iufs/apache-tomcat/webapps/iufs/WEB-INF/lib/asm
		
完整的错误日志信息: 2019-03-19 15:30:42,021 [main] INFO org.apache.catalina.core.StandardEngine- Starting Ser ...
 - Tomcat无法启动:org.apache.catalina.LifecycleException: Failed to start component 问题解决
		
问题如下:需要使用到数据库mysql,于是将mysql-connector-java-5.1.30-bin.jar的数据库驱动复制到WEE-INF/lib目录下.点击运行,但是服务器无法启动. 控制台 ...
 - java.lang.ClassNotFoundException: org.apache.catalina.startup.VersionLoggerListener
		
解决办法 找到Tomcat配置文件server.xml apache-tomcat-7.0.57/conf 将<Listener className="org.apache.cat ...
 
随机推荐
- Eclipse的使用技巧
			
Eclipse有强大的编辑功能, 工欲善其事,必先利其器, 掌握Eclipse快捷键,可以大大提高工作效率. 小坦克我花了一整天时间, 精选了一些常用的快捷键操作,并且精心录制了动画, 让你一看就会. ...
 - handsontable 问题
			
碰到问题了,去官网上找community:http://docs.handsontable.com/0.16.1/tutorial-quick-start.html 1. 描述:把handson ta ...
 - [mysql] mysql如何实现更新一条记录中某个字段值的一部分呢?
			
场景:在平常我们使用word文档等等office办公软件时,我们常会使用搜索->替换的功能. mysql: 在mysql 中有时候,我们也需要这样子的实现: 实现 SQL 语句: update ...
 - Django:model.save()的时候在干什么
			
转:https://www.cnblogs.com/zywscq/p/5397439.html Model.save(force_insert=False, force_update=False, u ...
 - C# winform  去掉button的边框颜色
			
Winform的话,设置FlatStyle为Flat,并且设置FlatAppearance下的BorderSize为0,foreColor设置成web下的Transparent
 - Caliburn.Micro(MVVM框架)
			
一.首启窗体设置 1. 创建一个新的WPF应用程序并添加NuGet包:Caliburn.Micro 2. 删除项目自带的主窗口文件MainWindow.xaml 3. 在App.xaml项目文件中,删 ...
 - JS时间戳转时间格式
			
//转化为时间格式 function getDate(timestamp) { timestamp = timestamp.replace("/Date(", "&quo ...
 - max渲染通道元素的范例
			
renderElementManager = MaxOps.GetCurRenderElementMgr() renderElementManager.Removeallrenderelements( ...
 - 使用Commons Email发送邮件
			
Commons Email是apache commons库中的一个组件,对java mail做了一些个封装,提供能为简化的API供开发者使用.它依赖于javax.mail . 首先下载commons- ...
 - 配置国内的maven仓库
			
MAVEN中央仓库 国内 配置Maven中央仓库路径的方法如下: 在Maven文件的conf目录中打开settings.xml文件 在文件中的servers节点和mirror节点中加入如下内容 华为云 ...