jar运行库载入(四)
2008-07-12 17:21
155 查看
前面讲述了main函数三段的主要任务,第一段基本库验证没什么好说的了。下面我们开始第二段的调试。
从上面我们可以看得出,首先,创建了一个Bootstrap对象,然后进入该对象的额init方法,进行初始化处理。下面我们看看init方法的内容:
setCatalinaHome()设置catalina.home的环境变量;setCatalinaBase()设置catalina.base的环境变量,一般是等于catalina.home。initClassLoaders()载入tomcat安装目录下,子目录common/lib、server/lib、shared/lib下的jar运行时库文件,并创建对应的三个classloader:commonLoader、catalinaLoader、sharedLoader,并且commonLoader是catalinaLoader和sharedLoader的父节点。
然后创建一个org.apache.catalina.startup.Catalina类对象,调用setParentClassLoader方法,将commonLoader赋予自己的parentClassLoader成员。保存Catalina对象。这样tomcat运行的时候,需要用到的类都载入到运行环境中了。
在tomcat运行时库的载入过程中,涉及到一些关键的类,它们得关系图如下。
在方法createClassLoader中,根据传入的参数,从配置文件/org/apache/catalina/startup/catalina.properties中,根据配置参数,遍历制定的目录,得到所有的jar文件列表,将这些列表载入到制定classloader中,实现了一个classloader子类StandardClassLoader,最后用运行时库的jar作为参数,创建一个StandardClassLoader放回。
对应的时序图为
根据上面的两个图,大家对tomcat运行时库的载入,然后创建一个org.apache.catalina.startup.Catalina对象应该有了一个大体的了解,这个Catalina对象保存为Bootstrap类的成员catalinaDaemon,这个对象后面将大有用处。如果对classloader有不理解的,可以在网上搜索相关的资料,就很容易理解了。
运行时库载入就好像一个windows程序运行的时候,需要载入一些lib库那样。
载入的具体细节,大家可以浏览具体的代码。如果有感兴趣的朋友,给我留言,我们一起学习研究。
if (daemon == null) { daemon = new Bootstrap(); try { daemon.init(); } catch (Throwable t) { t.printStackTrace(); return; } }
从上面我们可以看得出,首先,创建了一个Bootstrap对象,然后进入该对象的额init方法,进行初始化处理。下面我们看看init方法的内容:
public void init() throws Exception { // Set Catalina path setCatalinaHome(); setCatalinaBase(); initClassLoaders(); Thread.currentThread().setContextClassLoader(catalinaLoader); SecurityClassLoad.securityClassLoad(catalinaLoader); // Load our startup class and call its process() method if (debug >= 1) log("Loading startup class"); Class startupClass = catalinaLoader.loadClass ("org.apache.catalina.startup.Catalina"); Object startupInstance = startupClass.newInstance(); // Set the shared extensions class loader if (debug >= 1) log("Setting startup class properties"); String methodName = "setParentClassLoader"; Class paramTypes[] = new Class[1]; paramTypes[0] = Class.forName("java.lang.ClassLoader"); Object paramValues[] = new Object[1]; paramValues[0] = sharedLoader; Method method = startupInstance.getClass().getMethod(methodName, paramTypes); method.invoke(startupInstance, paramValues); catalinaDaemon = startupInstance; }
setCatalinaHome()设置catalina.home的环境变量;setCatalinaBase()设置catalina.base的环境变量,一般是等于catalina.home。initClassLoaders()载入tomcat安装目录下,子目录common/lib、server/lib、shared/lib下的jar运行时库文件,并创建对应的三个classloader:commonLoader、catalinaLoader、sharedLoader,并且commonLoader是catalinaLoader和sharedLoader的父节点。
然后创建一个org.apache.catalina.startup.Catalina类对象,调用setParentClassLoader方法,将commonLoader赋予自己的parentClassLoader成员。保存Catalina对象。这样tomcat运行的时候,需要用到的类都载入到运行环境中了。
在tomcat运行时库的载入过程中,涉及到一些关键的类,它们得关系图如下。
在方法createClassLoader中,根据传入的参数,从配置文件/org/apache/catalina/startup/catalina.properties中,根据配置参数,遍历制定的目录,得到所有的jar文件列表,将这些列表载入到制定classloader中,实现了一个classloader子类StandardClassLoader,最后用运行时库的jar作为参数,创建一个StandardClassLoader放回。
对应的时序图为
根据上面的两个图,大家对tomcat运行时库的载入,然后创建一个org.apache.catalina.startup.Catalina对象应该有了一个大体的了解,这个Catalina对象保存为Bootstrap类的成员catalinaDaemon,这个对象后面将大有用处。如果对classloader有不理解的,可以在网上搜索相关的资料,就很容易理解了。
运行时库载入就好像一个windows程序运行的时候,需要载入一些lib库那样。
载入的具体细节,大家可以浏览具体的代码。如果有感兴趣的朋友,给我留言,我们一起学习研究。
相关文章推荐
- dos查看jar运行异常
- hadoop 运行引用了第三方库的jar
- jetty-runner.jar指定端口运行war包
- cmd命令运行jar包
- 腾讯云Centos 7.0 服务器上运行Java脚本和jar文件
- 运行hadoop jar 命令时,依赖第三方Jar包的解决方法
- Linux在后台运行jar程序
- Java源码打包成可运行JAR:Eclipse实现
- Linux中启动和停止jar包的运行
- 运行jar包
- 程序运行时jar包报错问题
- linux下利用nohup后台运行jar文件包程序
- Android 运行jar
- 获得执行jar的运行路径-使用java.class.path 和 codesource的location
- java jar包命令行下可以双击不运行解决方法(改变java默认图标)
- 一个jar中含有多个主程序,想要运行指定主程序并打印日志
- yuicompressor-2.4.2.jar 和 YUIAnt-zh_CN.jar ANT 压缩JS文件,提高js运行速度
- IDEA打包可运行jar
- Eclipse导出为可运行的jar、删除工作空间的记录、删除启动配置的记录
- 用批处理运行可执行的的jar