需要:
1 各webapp使用的类库可独立,比如web1使用spring3,web2使用spring4
2 各webapp使用的类库可共享,比如10个webapp都使用同一份spring,都分开的话加载的类太多,方法区容易oom
3 web服务器安全不受webapp影响,服务器也依赖类库,服务器依赖类库可与webapp类库独立
4 jsp hotswap
改进:application classloader 的单个classpath拆分 ,定义多个类路径,多个classloader
CommonClassLoader 加载/common下类库,可被tomcat和所有webapp使用
CatalinaClassLoader 加载/server 下类库,可被tomcat使用
SharedClassLoader 加载/shared 下类库,可被所有webapp使用
WebAppClassLoader 加载/WEB-INF 下类库,可被单个webapp使用
JasperLoader 加载某张jsp对应的Class,jsp修改后,重新建立JasperLoader.
tomcat 6的改进:
/common,/server,/shared 改为/lib ,只用CommonClassLoader去加载,当然也手动配置开启以前的架构
问题:10个webapp都共享spring,spring类库放于/common下被CommonClassLoader加载,但是spring需访问用户的类(解析xml,生成BeanDefinition(含Class对象,需加载)),而spring显然访问不到用户类(使用加载自己的类加载器加载不到),得向下委托,怎么实现?
Thread Context ClassLoader去加载用户类。