Weblogic classloader分析

简介: 最近工作特别忙,现在才稍有点时间,准备探测一下weblogic的classloader。classloader的原理google上铺天盖地,这里就不再提及了。 首先采用两个用例测试一下基本的web应与EJB应用的classloader层次结构。

最近工作特别忙,现在才稍有点时间,准备探测一下weblogic的classloader。classloader的原理google上铺天盖地,这里就不再提及了。

首先采用两个用例测试一下基本的web应与EJB应用的classloader层次结构。测试的源代码提供在附件中了:

1. web应用,包括两个同内容不同名的JSP和两个同内容不同名的Servlet. JspLoader.jsp, jspLoader2.jsp, ServletLoader, ServletLoader2.

2. EJB应用   包括一个简单的EJB3.0 bean, LoaderBean和客户端EjbClient.

测试结果:

JSPLoader.Jsp:
Level1: sun.misc.Launcher$ExtClassLoader@18991b
Level2: sun.misc.Launcher$AppClassLoader@18ad61
Level3: weblogic.utils.classloaders.GenericClassLoader@a175d5 finder: weblogic.utils.classloaders.CodeGenClassFinder@27c1685 annotation:
Level4: weblogic.utils.classloaders.FilteringClassLoader@6c10df finder: weblogic.utils.classloaders.CodeGenClassFinder@6c1153 annotation:
Level5: weblogic.utils.classloaders.GenericClassLoader@6c1169 finder: weblogic.utils.classloaders.CodeGenClassFinder@6c11e2 annotation: TestClassLoader@
Level6: weblogic.utils.classloaders.ChangeAwareClassLoader@7f4e75 finder: weblogic.utils.classloaders.CodeGenClassFinder@7f4eea annotation: TestClassLoader@TestClassLoader.war
Level7: weblogic.servlet.jsp.TagFileClassLoader@816eac finder: weblogic.utils.classloaders.CodeGenClassFinder@816f22 annotation:
Level8: weblogic.servlet.jsp.JspClassLoader@1150af3 finder: weblogic.utils.classloaders.CodeGenClassFinder@1150b67 annotation:
SystemClassLoader: sun.misc.Launcher$AppClassLoader@18ad61

JSPLoader2.Jsp:
Level1: sun.misc.Launcher$ExtClassLoader@18991b
Level2: sun.misc.Launcher$AppClassLoader@18ad61
Level3: weblogic.utils.classloaders.GenericClassLoader@a175d5 finder: weblogic.utils.classloaders.CodeGenClassFinder@27c1685 annotation:
Level4: weblogic.utils.classloaders.FilteringClassLoader@6c10df finder: weblogic.utils.classloaders.CodeGenClassFinder@6c1153 annotation:
Level5: weblogic.utils.classloaders.GenericClassLoader@6c1169 finder: weblogic.utils.classloaders.CodeGenClassFinder@6c11e2 annotation: TestClassLoader@
Level6: weblogic.utils.classloaders.ChangeAwareClassLoader@7f4e75 finder: weblogic.utils.classloaders.CodeGenClassFinder@7f4eea annotation: TestClassLoader@TestClassLoader.war
Level7: weblogic.servlet.jsp.TagFileClassLoader@816eac finder: weblogic.utils.classloaders.CodeGenClassFinder@816f22 annotation:
Level8: weblogic.servlet.jsp.JspClassLoader@1150af3 finder: weblogic.utils.classloaders.CodeGenClassFinder@1150b67 annotation:
SystemClassLoader: sun.misc.Launcher$AppClassLoader@18ad61 

ServletLoader:
Level1: sun.misc.Launcher$ExtClassLoader@18991b
Level2: sun.misc.Launcher$AppClassLoader@18ad61
Level3: weblogic.utils.classloaders.GenericClassLoader@a175d5 finder: weblogic.utils.classloaders.CodeGenClassFinder@27c1685 annotation: 
Level4: weblogic.utils.classloaders.FilteringClassLoader@6c10df finder: weblogic.utils.classloaders.CodeGenClassFinder@6c1153 annotation: 
Level5: weblogic.utils.classloaders.GenericClassLoader@6c1169 finder: weblogic.utils.classloaders.CodeGenClassFinder@6c11e2 annotation: TestClassLoader@
Level6: weblogic.utils.classloaders.ChangeAwareClassLoader@7f4e75 finder: weblogic.utils.classloaders.CodeGenClassFinder@7f4eea annotation: TestClassLoader@TestClassLoader.war

SystemClassLoader: sun.misc.Launcher$AppClassLoader@18ad61

ServletLoader2:

Level1: sun.misc.Launcher$ExtClassLoader@18991b
Level2: sun.misc.Launcher$AppClassLoader@18ad61
Level3: weblogic.utils.classloaders.GenericClassLoader@a175d5 finder: weblogic.utils.classloaders.CodeGenClassFinder@27c1685 annotation: 
Level4: weblogic.utils.classloaders.FilteringClassLoader@6c10df finder: weblogic.utils.classloaders.CodeGenClassFinder@6c1153 annotation: 
Level5: weblogic.utils.classloaders.GenericClassLoader@6c1169 finder: weblogic.utils.classloaders.CodeGenClassFinder@6c11e2 annotation: TestClassLoader@
Level6: weblogic.utils.classloaders.ChangeAwareClassLoader@7f4e75 finder: weblogic.utils.classloaders.CodeGenClassFinder@7f4eea annotation: TestClassLoader@TestClassLoader.war

SystemClassLoader: sun.misc.Launcher$AppClassLoader@18ad61

EJB:
Level1: sun.misc.Launcher$ExtClassLoader@18991b
Level2: sun.misc.Launcher$AppClassLoader@18ad61
Level3: weblogic.utils.classloaders.GenericClassLoader@a175d5 finder: weblogic.utils.classloaders.CodeGenClassFinder@27c1685 annotation: 
Level4: weblogic.utils.classloaders.FilteringClassLoader@1e8de86 finder: weblogic.utils.classloaders.CodeGenClassFinder@1e8defa annotation: 
Level5: weblogic.utils.classloaders.GenericClassLoader@1e8df10 finder: weblogic.utils.classloaders.CodeGenClassFinder@1e8df89 annotation: TestEJB3Loader@

SystemClassLoader: sun.misc.Launcher$AppClassLoader@18ad61
从上面的结果首先以下结论:

同一Web应用的JSP或Servlet,其classloader的前六层是一样的(严格的说是7层,因为bootstrapClassLoader没输出,原因这里也不提了)。

对于JSP页面多了两层Classloader,TagFileClassLoader 和JspClassLoader,从上面结果可以看每个JSP文件对应一个JspClassLoader,而整个web应用的JSP页面共用一个TagFileClassLoader。

再看EJB,classloader的前三层与web应用的前三层是一样的,基本以为GenericClassLoader是用来加载weblogic的产品内部的相关类,前两层用来加载JDK的类,具体情况以后再做论述。

weblogic11g p3也是就10.3.4(oracle把weblogic的这个版本号搞得人晕头转向,后附一个版本对照表)添加了一个类分析工具Classloader Analysis Tool,以web应用的方式法提供。

在开发模式下可以用http://host:port/wls-cat来访问。可以帮助解决类冲突或研究weblogic的classloader结构,这里有两个文章可以参考。

http://blog.eisele.net/2011/01/using-new-weblogic-classloader-analysis.html https://blogs.oracle.com/jeffwest/entry/weblogic_1034_classloader_analysis_tool

                                         版本对照表

Release                              GA Date       Pre_Sup_Ends   Ext_Sup_Ends    Sus_Sup_Ends
WebLogic Server 12.1.x (12c)       - Dec 2011       Dec 2016       Dec 2019         Indefinite
WebLogic Server 11gR1 PS3 (10.3.4) - 15 Jan 2011    Jun 2014       Jun 2017         Indefinite    
WebLogic Server 11gR1 PS2 (10.3.3) - April 2010     Jun 2014       Jun 2017         Indefinite
WebLogic Server 11gR1 PS1 (10.3.2) - Nov 2009       Jun 2014       Jun 2017         Indefinite
WebLogic Server 11g (10.3.1)       - Jul 2009       Mar 2013       Mar 2015         Indefinite
WebLogic Server 10.3               - Aug 2008       Jan 2014       Jan 2017         Indefinite
WebLogic Server 10.0               - Mar 2007       Mar 2013       Mar 2015         Indefinite
WebLogic Server 9.x                - Nov 2006       Nov 2011       Nov 2013         Indefinite


本文转自 anranran 51CTO博客,原文链接:http://blog.51cto.com/guojuanjun/1024159


相关文章
|
安全 前端开发 Java
weblogic-CVE-2109漏洞分析
weblogic-CVE-2109漏洞分析
weblogic-CVE-2109漏洞分析
|
安全 Oracle 关系型数据库
游戏安全资讯精选 2017年第十九期:WebLogic Server WLS组件漏洞入侵挖矿事件分析,苹果手游代充灰色产业深度揭秘,《绝地求生》99%外挂都来自国内
WebLogic Server WLS组件漏洞入侵挖矿事件分析,苹果手游代充灰色产业深度揭秘,《绝地求生》99%外挂都来自国内
3963 0
|
Oracle Java 关系型数据库
|
Java 应用服务中间件 运维
|
XML Java 应用服务中间件
Apache CXF 在 WebLogic 9.2 上的问题定位分析及权宜之计
http://yulimin.javaeye.com/blog/129015 同样的程序在 Tomcat 5.5.16/25 以及 Jetty 5.1.12 上都能够成功部署及运行,但是部署到 WebLogic 9.2 上时出错 org.springframework.web.context.ContextLoader initWebApplicationContext FATAL: Con
1504 0
|
3月前
|
Java 应用服务中间件 Linux
centos7安装weblogic
centos7安装weblogic
|
负载均衡 Java 应用服务中间件
Weblogic的了解、安装及其使用(三)
Weblogic的了解、安装及其使用
1345 0
|
Oracle Java 关系型数据库
Weblogic的了解、安装及其使用(二)
Weblogic的了解、安装及其使用
992 0