dubbo的内核:SPI、AOP、IOC、compiler(动态编译)
这篇文章主要明SPI
1、什么是SPI
SPI英文为Service Provider Interface。
面向对象的设计里,模块与模块之间是基于接口编程,模块之间不对实现类进行硬编码,一旦代码时涉及具体实现类,就违反了可插拔的设计原则。如果需要替换一种实现,就要修改代码,为了实现在模块装配的时候,不在模块里写死,就需要一种服务发现机制,java SPI就实现了这各种机制。
为某个接品寻找服务实现机制,有点类似于IOC的思想民,就是将装配的控制权移到了代码之外。
2、SPI约定
当服务的提供者提供了一个接口多个实现时,一般会在jar包的META-INF/services/目录下创建该接口的同文件,该文件里的内容就是该接口服务的具体实现类的名称。而外部加载这个模块的时候,就能通过该jav包的META-INF/services里面的配置文件得到具体实现类名,并加载实例化,完成模块的装配。
JDK提供服务实现查找的一个工具类:java.util.ServiceLoader。
很多框架都使用了java的SPI机制,如JDBC4中的java.sql.Driver的SPI实现(mysql驱动、oracle驱动等)、common-logging的日志接口实现。
下面我们来看一个mysql驱动包实现: