2.dubbo源码-SPI

2017-11-02  本文已影响466人  阿飞的博客

SPI

SPI:Serivce Provider Interface,为接口寻找服务实现的机制。有点类似IOC的思想,就是将装配的控制权移到程序之外,在模块化设计中这个机制尤其重要。

Java标准SPI

参考链接传送门

dubbo自定义SPI

dubbo为什么要自定义SPI?因为Java标准SPI有一些缺点:

dubbo协议

以com.alibaba.dubbo.rpc.Protocol为例,@SPI指定默认协议,即默认dubbo协议,源码如下:

/**
 * Protocol. (API/SPI, Singleton, ThreadSafe)
 * 
 * @author william.liangf
 */
@SPI("dubbo")
public interface Protocol {

SPI注解指定的value即dubbo就是key,对应dubbo-rpc-default模块下的META-INF/dubbo/internal/com.alibaba.dubbo.rpc.Protocol文件中:dubbo=com.alibaba.dubbo.rpc.protocol.dubbo.DubboProtocol,即为dubbo协议默认实现,这个实现过程在接下来的学习过程中会讲到;

dubbo线程池

同样的,能够得到dubbo默认采用的线程池实现,dubbo-common模块下com.alibaba.dubbo.common.threadpool.ThreadPool的源码:

/**
 * ThreadPool
 * 
 * @author william.liangf
 */
@SPI("fixed")
public interface ThreadPool {
    
    /**
     * 线程池
     * 
     * @param url 线程参数
     * @return 线程池
     */
    @Adaptive({Constants.THREADPOOL_KEY})
    Executor getExecutor(URL url);

}

META-INF/dubbo/internal/com.alibaba.dubbo.common.threadpool.ThreadPool中定义如下:
fixed=com.alibaba.dubbo.common.threadpool.support.fixed.FixedThreadPool
cached=com.alibaba.dubbo.common.threadpool.support.cached.CachedThreadPool
limited=com.alibaba.dubbo.common.threadpool.support.limited.LimitedThreadPool
所以,dubbo默认线程池实现为fixed对应的实现:com.alibaba.dubbo.common.threadpool.support.fixed.FixedThreadPool,即固定(200个,通过Constants.DEFAULT_THREADS定义)线程池;

上一篇下一篇

猜你喜欢

热点阅读