tomcat的类加载器+日志系统 学习笔记

前言:tomcat类加载器的文章网上很多,坛子里也有很多,就不重复造轮子了

分享两篇相关好问地址:http://www.ibm.com/developerworks/cn/java/j-lo-classloader/index.html

http://blogold.chinaunix.net/u2/83532/showart_1418390.html

看东西前,为自己提几个问题

tomcat为什么需要类加载器,已有的jvm设计的加载器为何满足不了,类加载器都为tomcat做了什么呢,?

资料上说

引用

比如您的应用通过网络来传输Java类的字节代码,为了保证安全性,这些字节代码经过了加密处理。这个时候您就需要自己的类加载器来从某个网络地址上读取加密后的字节代码,接着进行解密和验证,最后定义出要在Java虚拟机中运行的类来

那么tomcat是为啥子呢?没怎么想通,goole了几次找到相关的说法

引用

container中需要一个自定义的loader,不能简单的直接使用系统的loader,因为所要运行的servlet是不可信任的。假如像使用之前章节一样使用系统中的loader,则该loader载入的servlet和其他类就能访问当前jvm实例中CLASSPATH环境变量下所有的类了,这非常不安全。servlet应该仅仅被允许从WEB-INF/classes及其子目录,和WEB-INF/lib下部署额lib中载入类。因此,servlet容器需要一个自定义的loader。每一个web一样(对应context容器)都有一个自定义的loader。在catalina中,loader组件要实现org.apache.catalina.Loader接口。

使用自定义loader的另一个原因是,可以支持class的自动重载。tomcat中的loader实现使用了另一个线程来检查servlet和相关类的时间戳,若是发生变化,则重新载入。为了支持class的重载,loader还要实现org.apache.catalina.loader.Reloader接口。

里面设计到线程加载器,必须要指定,不过不知道就会jvm顶层加载器去加载了。

tomcat实现里面有很多自己的策略,具体的东西大概看了下,没深入。

日志系统,在系统每个类都可以看到他的存在,但是tomcat确使用了的这个是可扩展性的吗?他可以随意替换日志输出吗?那么java本身是日志框架是怎样的,貌似这个要再java本身有一个好的支持,因为在里面看到很多java.util.log

详细资料http://tomcat.apache.org/tomcat-6.0-doc/logging.html

commonlogging:http://commons.apache.org/logging/

这就完全解释了为什么看到

private static final String SIMPLE_FMT="org.apache.tomcat.util.log.JdkLoggerFormatter";
    private static final String SIMPLE_CFG="org.apache.tomcat.util.log.JdkLoggerConfig";

相关推荐