yJDBC是如何打破双亲委派模式的 - 掘金为什么JDBC需要打破双亲委派机制 JDBC的DriverManager与SPI机制 类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制 在JDBC 4.0之后,我们不再需要调用Class.https://juejin.cn/post/7007292903361871903为什么JDBC需要打破双亲委派机制 JDBC的DriverManager与SPI机制 类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制 在JDBC 4.0之后,我们不再需要调用Class.https://juejin.cn/post/7007292903361871903
为什么JDBC需要打破双亲委派机制
JDBC的DriverManager与SPI机制
类加载的机制以及双亲委派机制的介绍可以参考 JVM类加载机制
在JDBC 4.0之后,我们不再需要调用Class.forName()方法去加载驱动类。只需要将对应的驱动类jar包放到工程的class path下,驱动类会自动被加载。
这种自动加载的技术被称为SPI(Service Privider Interface)[3],SPI可以简单理解为:为了解耦,从配置里获取某个接口的具体实现类。各个数据库也都更新支持了这个特性。包括MySQL-JDBC等,每个JDBC的jar包里都有一个META-INF/services
目录,里面有一个 java.sql.Driver
文件,里面指定了这个driver的实现类的全限定名。
DriverManager的类加载问题
类加载的范围受到限制,某些情况下父class loader无法加载某些类文件,这时候就需要委托到下层级的class loader去加载类文件。
JDBC的driver接口定义在JDK中,但是它的实现类是放在classpath下的(比如MySQL)。
- DriverManager类会加载每个Driver接口的实现类并管理它们,但是DriverManager类自身是
jre/lib/rt.jar
里的类,是由bootstrap classloader加载的- 根据类加载机制,某个类需要引用其它类的时候,虚拟机将会用这个类的classloader去加载被引用的类
- boostrap classloader显然是无法加载到MySQL driver的(ClassNotFoundException)
- 因此只能在DriverManager里强行指定下层classloader来加载Driver实现类,而这就会打破双亲委派模型