The driver is automatically registered via the SPI -这是啥含义?

2023-11-03

jdbc.Driver 被自动注册了?这里面牵扯到几件事,一一道来;

1. 何为SPI,它是如何把Driver加载进去的;

SPI ,全名:Service Provider Interface. ,是一种服务发现机制。它通过在ClassPath路径下的META-INF/services文件夹查找文件,自动加载文件里所定义的类。

带着疑问,我们打开mysql-connect-java包,看到了上面描述的配置文件:

那它是如何做到的呢?为啥加载到这儿了,我们带着代码来看看~

在DriverManager 类里面有个loadInitialDrivers,里面有个load ,如下图:

ServiceLoader<Driver> loadedDrivers = ServiceLoader.load(Driver.class);

我们点进去瞅瞅,从ServiceLoader 发现了端倪:

调用栈如下,在加载 HikariDataSource 对象时候调用到:

 

2. 这边用到了SPI,它和双亲委派什么关系?

SPI 会打破双亲委派机制。

类加载的范围受到限制,某些情况下父class loader无法加载某些类文件,这时候就需要委托到下层级的class loader去加载类文件。 [1]

JDBC的driver接口定义在JDK中,但是它的实现类是放在classpath下的(比如MySQL)。

  • DriverManager类会加载每个Driver接口的实现类并管理它们,但是DriverManager类自身是 jre/lib/rt.jar 里的类,是由bootstrap classloader加载的
  • 根据类加载机制,某个类需要引用其它类的时候,虚拟机将会用这个类的classloader去加载被引用的类
  • boostrap classloader显然是无法加载到MySQL driver的(ClassNotFoundException)
  • 因此只能在DriverManager里强行指定下层classloader来加载Driver实现类,而这就会打破双亲委派模型

参考链接:https://juejin.cn/post/7007292903361871903

PS:还有一种打破双亲委派的方式,自定义loadClass, tomcat就是这么干的。

3. 我没有主动配置数据连接池,默认是啥,性能如何?

看了下日志,发现默认的数据库连接池是 HikariDataSource。

有点疑问的是,有些文章默认用的Druid连接池,那两者有啥差距呢?好奇搜了搜,结论如下:

所以还是乖乖地使用大家帮忙选的这个数据库连接池吧~~~

(20条消息) 02、连接池hiKariCP和druid的使用以及良心对比_不要停止思考-jcn的博客-CSDN博客_druid hikaricp

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

The driver is automatically registered via the SPI -这是啥含义? 的相关文章

  • spring-security java 配置:如何配置多个 AuthenticationManager 实例

    I use 春季启动 1 1 7 弹簧安全 4 0 0 M2 spring fmk 4 1 1 RELEASE 一切都是用Java Config配置的 包括spring security 我正在开发一个 Web 服务器项目 其中 Authe
  • 根据多行中的总分对 mysql 中的用户进行排名

    我有与这个问题中描述的非常相似的要求 mysql中的用户按积分排名 https stackoverflow com questions 34637943 rank users in mysql by their points 唯一的区别在于
  • MySQL 可以存储多少行?

    所以我是一个初学者 刚刚自学了几个月的MySQL 我在工作中总是使用 phpMyAdmin 我过去的工作只涉及大约 100k 行的表 所以没有什么大问题 然而 我的客户现在想要在表中存储大约 800 万行 MySQL phpMyAdmin
  • 如何在 Spring boot 应用程序中使用禁用连接池?

    我在 Application java 中创建一个像这样的数据源 Bean ConfigurationProperties datasource public DataSource dataSource return DataSourceB
  • PHP - While/Else 错误? [关闭]

    这个问题不太可能对任何未来的访客有帮助 它只与一个较小的地理区域 一个特定的时间点或一个非常狭窄的情况相关 通常不适用于全世界的互联网受众 为了帮助使这个问题更广泛地适用 访问帮助中心 help reopen questions 我有以下
  • 在 spring 上下文中定义一个字符串

    我有三个 A B C spring context xml A用于基本配置 B和C导入A 在 A 上的豆子中我有
  • 如何将UTF-8编码的汉字从MySql正确导出到SQL

    过去三天我们正在与严重的问题作斗争 我们从PhpmyAdmin导出MySql数据库文件 数据库条目中写入的数据是带有UTF 8字符集的中文 导出后将其转换为拉丁字符集 现在我们正在将此数据库SQl文件导入到其他主机 我们在UTF 8和排序规
  • Apache Tiles 退休了。备择方案?

    Apache Tiles 于 2018 年 12 月迁入阁楼 因此 Apache Tiles 已经退休 我正在使用 Spring MVC 框架和 JSP 还有哪些替代方案 我看到了Sitemesh 但它是一个装饰器 我需要一个模板框架 我想
  • mysql错误1442的真正原因是什么?

    好吧 我在互联网上寻找了很多地方来寻找原因mysql error 1442其中说 无法更新存储函数 触发器中的表 unlucky table 因为 它已被调用此存储的语句使用 功能 触发器 有人说这是 mysql 中的一个错误或者它不提供的
  • SQLite 数据库安全

    我正在构建一个使用 Sqlite DB 的应用程序 用户可以将他们的信息输入数据库并检索它们 但是 我希望他们能够备份 sqlite 数据库 我所做的是将 sqlite 数据库放入文档文件夹中 以便他们可以使用 iTunes 将其检索出来
  • 分段文件上传:Spring Boot中的大小超出异常返回JSON错误消息

    由于我设置了最大文件上传限制 我得到 org apache tomcat util http fileupload FileUploadBase FileSizeLimitExceededException The field file e
  • mysql - 选择日期时间和组中的小时

    我有一个 ShoppingDates 的日期时间列 假设我有 1000 行 2012 年 7 月 18 日 5 33 39 下午 2012 年 7 月 16 日 6 64 39 下午 2012 年 7 月 14 日 7 34 39 下午 2
  • 如何在同一列中选择多个值?

    我正在尝试在单个列中选择多个值 基本上我希望查询选择列下的所有内容family有价值观Software 1Y XI 1Y and P1 1Y 我正在运行这个查询 SELECT salesorder masterproduct family
  • 带嵌入式 tomcat 的 spring-boot 不会将请求分派到控制器

    我有一个使用 spring boot 和嵌入式 Tomcat 容器的应用程序 据我所知 我的代码与 spring boot 相同示例项目 https github com spring projects spring boot tree m
  • 新行分隔符不适用于 group_concat 函数

    我有一根绳子 name lastname name2 lastname2 包含数据库表中的值 我想显示它 喜欢 name lastname name2 lastname2 我使用 group concat 函数 它适用于逗号分隔符 但我需要
  • 如何在 SpringBoot v3.0.0 中使用嵌入式 MongoDB?

    我正在尝试连接嵌入式 mongodb 并使用 MongoDbSpringIntegrationTest 对其进行测试 问题是相同的代码在 2 7 7 中适用于 spring boot 但在 3 0 0 中不适用于 spring boot 问
  • .NET 表适配器:获取与填充?

    在处理数据库中的数据 强类型或其他方式 时 我似乎总是使用 Get 并且我从未真正需要使用 Fill 尽管在提取和更新数据时我可以轻松地使用 Fill 而不是 get 任何人都可以提供有关每种方法的含义和陷阱的指导吗 在什么情况下最好使用其
  • 删除 ibdata1 后 MySQL 表消失了

    几天前 经过一番谷歌搜索后 我发现了这篇文章 我无法再让 mysql 运行了 xampp XAMPP MySQL 意外关闭 https stackoverflow com questions 18022809 xampp mysql shu
  • mysql 准备好的语句错误:MySQLSyntaxErrorException

    我使用准备好的语句编写了选择语句 每次尝试运行都会出现此错误 我如何克服这个错误 我的jdbc连接器是mysql connector java 5 1 13 bin jar 我的代码 public Main add ad to getAdD
  • 如何检测数据库类型?

    我需要确保我连接的数据库是 MySQL 而不是 PostgreSQL 或 Microsoft SQL Server 我怎样才能知道正在使用哪种类型的数据库 第一个提示可能是如果您尝试使用 mySQL 数据库驱动程序连接到 PostgreSQ

随机推荐

  • Rational Rose 7.0安装教程

    关注公众号 免费获取资料 简介 Rational Rose是Rational公司出品的一种面向对象的统一建模语言的可视化建模工具 用于可视化建模和公司级水平软件应用的组件构造 就像一个戏剧导演设计一个剧本一样 一个软件设计师使用Ration
  • 性能测试之性能监控和性能优化

    目录 一 概述 二 jconsole和jvisualvm 三 jconsole 四 visualvm 1 输入命令提示 jvisualvm不是内部或外部命令 也不是可运行的程序或批处理文件 2 打开jvisualvm里面不包含GC监控 五
  • 基于低代码平台实现的免费CRM系统

    编者按 企业生存的根本是客户资源 因此客户关系的管理对于企业来说至关重要 目前我国中小企业对于客户的管理方法不够重视 以致于客户外流 客户转化率不高 而CRM客户关系管理系统有助于企业培养和增强客户关系 下面就让我们一起来了解一下企业该如何
  • 使用Java编写的简单行为树

    引言 试着用java把以前用c 写的行为树复现了出来 代码 import java util Random 假设有一士兵 初始生命为100 弹药为200发 每个弹匣40发 会逃跑 会巡逻 会攻击 会换弹 会补给 会发现敌人 class So
  • MyBatis基础语法

    1 namespace用于指定dao Mapper 层文件的路径 2 property传入的值与po SysUser的属性对应 3 column传入的值与数据库的字段对应 4 javaType传入的值 路径 是java这边的数据类型 5 j
  • C语言写九九乘法表(五种方法)

    当我们学习编程语言时 通常需要掌握一些基本的语法和功能 在C语言中 输出九九乘法表是一个很好的练习 因为它既简单又有趣 本文将介绍如何用C语言编写代码来输出九九乘法表 在开始之前 请确保您已经安装了C语言的开发环境 比如VS2019 首先
  • el-input 怎么添加鼠标悬浮内容展示

    您可以通过使用el tooltip组件的content属性将提示框附加到el input中 然后 您可以添加一个文本框和图标 当鼠标悬停在这些元素上时 提示框就会显示 以下是示例代码
  • 在 Python 中使用 MQTT的方法

    更多编程教程请到 菜鸟教程 https www piaodoo com 友情链接 高州阳光论坛https www hnthzk com Python 是一种广泛使用的解释型 高级编程 通用型编程语言 Python 的设计哲学强调代码的可读性
  • 【华为OD机试真题 python】组装最大可靠性设备【2023 Q2

    前言 华为OD笔试真题 python 本专栏包含华为OD机试真题 会实时更新收纳网友反馈 为大家更新最新的华为德科OD机试试题 为大家提供学习和练手的题库 订阅本专栏后可私信进交流群哦 题目描述 组装最大可靠性设备 一个设备由N种类型元器件
  • QT的UDP协议

    UDP协议 客户端并不与服务器建立连接 它只负责调用发送函 数向服务器发出数据报 类似地 服务器也不从客户端接收连接 只负责调用接 收函数 等待来自某客户端的数据到达 客户端 端口号 quint64 初始化端口 quint64 port 5
  • idea 出现 Failure to find org.eclipse.m2e:lifecycle-mapping:pom:1.0.0 in http://maven.aliyun.com/

    使用mybatis autogenerator时失败 显示Failure to find org eclipse m2e lifecycle mapping pom 1 0 0 in http maven aliyun com nexus
  • G - 数据结构实验之栈与队列七:出栈序列判定

    Description 给一个初始的入栈序列 其次序即为元素的入栈次序 栈顶元素可以随时出栈 每个元素只能入栈依次 输入一个入栈序列 后面依次输入多个序列 请判断这些序列是否为所给入栈序列合法的出栈序列 例如序列1 2 3 4 5是某栈的压
  • Flutter中EventBus组件的使用

    1 首先导入使用EventBus时所需的包 event bus 1 1 1 2 还需要一个EventBus工具类 import dart async import package event bus event bus dart impor
  • QT打包exe程序

    文章目录 1 Release版本编译 2 发布给别人的版本 1 Release版本编译 qt选择release编译后 到对应release文件夹找到exe 双击运行 如果运行不了或者报错缺少dll文件 大概率是没有添加环境变量 打开系统环境
  • 第一次使用Android Studio时你应该知道的一切配置

    http www cnblogs com smyhvae p 4390905 html
  • Linux系统目录简介及常规操作命令

    文件类型 普通文件 regular file 就是一般存取的文件 由ls al显示出来的属性中 第一个属性为 例如 rwxrwxrwx 另外 依照文件的内容 又大致可以分为 1 纯文本文件 ASCII 这是Unix系统中最多的一种文件类型
  • 关系型数据库(mysql等)和非关系型数据库(Redis、ElasticSearch、HBase等)对比

    目录 一 关系型数据库 二 非关系型数据库 1 缓存型数据库 1 Redis 2 Memcached 2 文档型数据库 1 ElasticSearc 2 mongoDB 3 列式型数据库 1 HBase 2 Cassandra 一 关系型数
  • 玩无人机必备!PID调节经验

    Kp 比例系数 比例带 比例度 P 输入偏差信号变化的相对值与输出信号变化的相对值之比的百分数表示 比例系数的倒数 T 采样时间 Ti 积分时间 Td 微分时间 温度T P 20 60 Ti 180 600s Td 3 180s 压力P P
  • Linux nrm 运行失败,linux – npm安装失败

    我首先要说的是 我没有在终端或使用node js工作的经验 同事离开度假 我试图按照他离开的说明在我们的演示服务器上设置他的应用程序 我可以在本地运行所有内容 但是在安装socket io模块的服务器上遇到问题 安装了python 安装了n
  • The driver is automatically registered via the SPI -这是啥含义?

    jdbc Driver 被自动注册了 这里面牵扯到几件事 一一道来 1 何为SPI 它是如何把Driver加载进去的 SPI 全名 Service Provider Interface 是一种服务发现机制 它通过在ClassPath路径下的