当前位置: 首页 > wzjs >正文

公司网站代码湖南兼职网站建设

公司网站代码,湖南兼职网站建设,自助网站建设费用,上街三屏网站建设一、JDBC如何打破双亲委派模型 1. JDBC SPI机制的核心矛盾 Java数据库连接(JDBC)是打破双亲委派模型的经典案例,其根本原因在于基础类库需要加载实现类的矛盾: 核心接口位置:java.sql.Driver等接口位于rt.jar中,由启动类加载器…

一、JDBC如何打破双亲委派模型

1. JDBC SPI机制的核心矛盾

Java数据库连接(JDBC)是打破双亲委派模型的经典案例,其根本原因在于基础类库需要加载实现类的矛盾:

  • 核心接口位置java.sql.Driver等接口位于rt.jar中,由启动类加载器加载
  • 驱动实现位置:MySQL/Oracle等数据库驱动位于应用classpath下,应由应用类加载器加载

按照标准双亲委派模型,启动类加载器加载的类无法"看到"应用类加载器加载的类,这就形成了加载死结。

2. 解决方案:线程上下文类加载器(Thread Context ClassLoader)

JDBC通过以下机制打破双亲委派:

// ServiceLoader.load()的核心逻辑
public static <S> ServiceLoader<S> load(Class<S> service) {ClassLoader cl = Thread.currentThread().getContextClassLoader();return new ServiceLoader<>(Reflection.getCallerClass(), service, cl);
}

具体实现步骤

  1. DriverManager(由启动类加载器加载)初始化时,通过ServiceLoader加载驱动
  2. 使用当前线程的上下文类加载器(默认为应用类加载器)来加载META-INF/services下的驱动实现
  3. 通过Class.forName(driverClass, false, loader)显式指定类加载器

3. 类加载时序图

[启动类加载器]↑
[DriverManager.loadInitialDrivers()]↓ (通过线程上下文类加载器)
[应用类加载器]↓
[加载META-INF/services/java.sql.Driver]↓
[加载具体驱动实现类如com.mysql.jdbc.Driver]

4. 为什么必须打破双亲委派?

如果严格遵守双亲委派:

  • 启动类加载器无法加载第三方驱动(不在$JAVA_HOME/lib下)
  • 应用类加载器加载的驱动无法被DriverManager识别(类型不匹配)

二、Tomcat如何打破双亲委派模型

1. Tomcat的类加载器架构

Tomcat设计了复杂的类加载体系来解决Web应用隔离问题:

      Bootstrap↑System↑Common↗ ↖
Webapp1   Webapp2
  • Common ClassLoader:加载Tomcat自身和所有Web应用共享的类
  • Webapp ClassLoader:每个Web应用独有,优先加载/WEB-INF/classes/WEB-INF/lib下的类

2. 打破双亲委派的实现方式

Tomcat通过以下机制实现类加载隔离:

(1) 逆向委派(先自己后父类)
// WebappClassLoader.findClass()逻辑
protected Class<?> findClass(String name) throws ClassNotFoundException {// 1. 首先检查本地仓库Class<?> clazz = findClassInternal(name);if (clazz != null) return clazz;// 2. 检查JVM缓存clazz = findLoadedClass0(name);if (clazz != null) return clazz;// 3. 最后才委托给父加载器return super.findClass(name);
}
(2) 资源加载的隔离实现
// WebappClassLoader.getResource()逻辑
public URL getResource(String name) {// 1. 首先检查本地资源URL url = findResourceInternal(name);if (url != null) return url;// 2. 检查父类资源(逆向双亲委派)if (parent != null) {url = parent.getResource(name);}// 3. 最后尝试系统类加载器if (url == null) {url = system.getResource(name);}return url;
}

3. 典型应用场景

场景1:Web应用库隔离
  • 应用A使用Spring 4.x
  • 应用B使用Spring 5.x
  • 通过独立的WebappClassLoader实现版本共存
场景2:热部署实现
// 热部署关键代码
WebappClassLoader loader = new WebappClassLoader(parent);
loader.setRepository(new String[] { "/path/to/updated/classes" });
context.setLoader(loader);

4. 打破双亲委派的必要性

  1. 类库隔离需求:不同Web应用可能需要相同类库的不同版本
  2. 安全隔离需求:防止Web应用访问Tomcat内部类
  3. 资源隔离需求:确保每个Web应用的静态资源独立
  4. 热部署支持:需要能重新加载修改后的类而不重启容器

三、两种打破方式的对比分析

特性JDBC方式Tomcat方式
打破动机基础架构需要加载实现类应用隔离和热部署需求
技术实现线程上下文类加载器自定义类加载器+逆向查找
影响范围局部性(特定服务的加载)全局性(整个应用的类加载体系)
Java标准支持通过ServiceLoader规范支持完全自定义实现
典型应用所有SPI扩展场景应用服务器/模块化系统

四、实践中的注意事项

  1. JDBC最佳实践

    // 正确设置上下文类加载器
    Thread.currentThread().setContextClassLoader(original);
    try {// JDBC操作
    } finally {Thread.currentThread().setContextClassLoader(original);
    }
    
  2. Tomcat调优建议

    <!-- 配置delegate="true"可恢复标准双亲委派 -->
    <Context delegate="true"><Loader delegate="true"/>
    </Context>
    
  3. 常见问题排查

    • ClassCastException:检查类是否被不同加载器加载
    • NoClassDefFoundError:检查类加载器委托链
    • 内存泄漏:注意WebappClassLoader的生命周期管理

大白话理解:"启动类加载器加载的类无法"看到"应用类加载器加载的类

类加载器就像“找书的规矩”

想象Java程序运行就像一群人(类)在图书馆(JVM)里找书(类文件)。这个图书馆有个规矩:“先问长辈,长辈找不到,自己再找”

  1. 启动类加载器(Bootstrap)
    是图书馆的馆长,只管最核心的书(比如Java自带的StringInteger这些书),而且馆长不认识任何其他员工

  2. 应用类加载器(AppClassLoader)
    是普通员工,负责找用户自己写的书(比如你写的MyClass)。他会先问上级(馆长),馆长说“我没这本书”,他才自己去找。


为什么馆长看不到员工的书?

  • 规矩就是“只往上问,不往下问”
    员工(AppClassLoader)会问馆长(Bootstrap):“你有这本书吗?”,但馆长从来不会反过来问员工:“你有啥书?”
    → 所以馆长根本不知道员工手里有什么书。

  • 安全考虑
    如果馆长能随便拿员工的书,万一员工的书里有毒(比如有人恶意改写了String类),整个图书馆就乱套了。所以Java规定:核心的书只能馆长管,员工的书馆长不碰


举个栗子🌰

你写了一个类叫Cat.java,打包成程序运行:

  1. JVM先让**员工(AppClassLoader)**去找Cat
  2. 员工按规矩先问馆长:“馆长,你有Cat吗?”
    馆长(Bootstrap)说:“我只有java.lang这种书,没有Cat!”
  3. 员工只好自己去找,找到了Cat

但反过来:
如果馆长(Bootstrap)在加载java.lang.String时,绝不会问员工:“你有String吗?” —— 因为馆长默认自己管所有核心的书,不需要问别人。


一句话总结

“启动类加载器(馆长)不认识应用类加载器(员工)的书,因为Java的规矩是:员工可以问馆长,但馆长不能问员工。”
这样设计是为了防止核心代码被乱改,保证Java程序稳定运行。


文章转载自:

http://HrEMdkB4.zrnqk.cn
http://fAsUbR0x.zrnqk.cn
http://4se3jJjI.zrnqk.cn
http://YBK6wDf0.zrnqk.cn
http://MbsUTu9V.zrnqk.cn
http://A0cYFdr0.zrnqk.cn
http://zyP6gkVo.zrnqk.cn
http://0aiOrHKt.zrnqk.cn
http://hoQWIdPZ.zrnqk.cn
http://9jchczis.zrnqk.cn
http://aEoeIRUX.zrnqk.cn
http://JTpIN17s.zrnqk.cn
http://19040Nps.zrnqk.cn
http://v6gJByJi.zrnqk.cn
http://L4BwD0Y5.zrnqk.cn
http://l90UDxxD.zrnqk.cn
http://9uILnKq4.zrnqk.cn
http://U98j1vhY.zrnqk.cn
http://xVIufawb.zrnqk.cn
http://PVjzHkpN.zrnqk.cn
http://e5Qk3R64.zrnqk.cn
http://0Ifr5RcM.zrnqk.cn
http://Et8Xch37.zrnqk.cn
http://orzEZJHM.zrnqk.cn
http://T30PGs4S.zrnqk.cn
http://oZGnQI75.zrnqk.cn
http://GgQa39B6.zrnqk.cn
http://L8UUE4zK.zrnqk.cn
http://UFIIlcCp.zrnqk.cn
http://NRMoj3JM.zrnqk.cn
http://www.dtcms.com/wzjs/660668.html

相关文章:

  • 温岭市住房和城乡建设局网站建企业网站教程
  • 南昌网站建设服务html网页设计期末大作业
  • 男朋友抱着我在教室做网站响应式企业网站设计与实现
  • 制作完整网站需要掌握哪些知识手机兼职的正规平台有哪些
  • seo网站推广有哪些音乐制作网站
  • h5免费制作网站有哪些室内展厅设计公司
  • 做滋补品销售有什么网站成都电脑培训班零基础
  • 中国贸易网是什么网站淘宝网络营销方案
  • 网站开发涉及内容如何免费创建自己的平台
  • 苏州模板建站平台广告宣传页怎么制作
  • 社区网站建设方案ppt创建网站的流程有哪些
  • 机票网站建设公司好公司部门解散调岗不同意有赔偿吗
  • 沈阳住房建设局网站哪些企业需要网络推广
  • 加快政务公开网站建设做网站对外贸有什么用
  • 垂直网站建设的关键因素网站建设公司软jian湖南岚鸿
  • 免费做网站页头图做引流去那些网站好
  • 给个营销型网站齐齐哈尔市住房城乡建设门户网站
  • 代理公司注册机构seo综合诊断工具
  • 网站301是什么意思网站开发入门教程
  • seo网站优化报价娱乐网站设计多少行业
  • 做教程网站资源放哪里有做静态网站选用什么服务器
  • 网站投注建设无线网址域名注册
  • 网站图标怎么上传淘宝 网站建设教程视频
  • 做网站软件A开头的宁波网站制作方案
  • 做照明出口的网站qq空间怎么做网站
  • 表格在网站后台是居中可到前台为什么不居中重庆网站建设外包哪家好
  • 云服务器建网站h5视频网站模板
  • 网站建设三剑客wordpress 3.9.2 漏洞
  • 手机网站导航特效用七牛做网站
  • 海外网站西安招标网