ShardingSphere分库分表应用实战
admin
2024-02-09 11:42:16

一、SPI

SPI(动态扩展机制)

  • Java原生SPI
  • Dubbo (Dubbo自己实现的一个SPI)
  • Spring(SpringFactoriesLoader)
  • Sentinel()
  • ShardingSphere(Java SPI)

SPI实现

  • META/service的目录放在classpath目录下
  • 扩展类全限定名组成的文件名
  • 文件内容填写该扩展类的实现类
  • ServiceLoad.load(Driver.class)
    • 会从classpath目录下 META-INF/service目录下找到java.sql.Driver的文件名 [list]
    • 解析这些文件
    • 得到所有文件中填写的实现类

关于Java中的SPI机制
SPI 的全名为 Service Provider Interface,它的核心思想是中间件中定义标准,然后使用者可以在这个标准上实现自定义扩展,举个比较常见的例子,就是JDBC驱动。 Java官方只提供了JDBC驱动的接口java.sql.Driver,然后各大数据库厂商,如Mysql、Oracle都会基于这个接口定义不同数据库的连接实现,然后使用java语言的开发者不需要关心不同数据库的具体配置,只需要集成相关的依赖包以及配置相关驱动,Java程序就能自动匹配到相关的实现完成数据库连接。这种思想在很多地方都有使用,比如Spring中的SpringFactoriesLoader、Dubbo中的S

相关内容

热门资讯

原创 再... 这4道汤品温润滋补,养胃不伤身、益肾强免疫,适合日常调养,坚持喝脾胃舒服、元气足、抵抗力更好。 一、...
原创 一... 大千世界总是令人很奇妙,当人们遇到不愉快的事情的时候,总是会被“做人咧,最紧要就系开心”这句经典台词...
原创 群... 玻璃门上那张"房东直租"的告示,把群哥水煮蛙最后一点体面也撕了下来。 红色招牌还在,灯却再也不会亮。...
“食”不相瞒!长治养老陪餐制度... “大爷,今天这豆角焖面软硬咋样?黄焖鸡块合口不?” “不错!软乎、香,正适合我们这岁数的人吃!” 5...