Dubbo之Protocol

dubbo版本

  1. dubbo版本2.6.7

Protocol

  1. Protocol层主要包含ProtocolFilterExporterListenerInvokerListenerProtocol层是RPC的核心调用层,具体的RPC协议都可以通过Protocol扩展。Protocol接口是入口,主要用来封装Exporter和Invoker的方法,Protocol#export将服务暴露的处理过程,Invoker标识服务远程代理对象

    /**
     * Protocol. (API/SPI, Singleton, ThreadSafe)
     */
    @SPI("dubbo")
    public interface Protocol {
    
        /**
         *当用户没有配置端口时获取默认端口
         *
         * @return default port
         */
        int getDefaultPort();
    
        /**
         * 暴露远程服务: <br>
         * 1. 协议在接收请求时,应记录请求来源方地址信息:
         * RpcContext.getContext().setRemoteAddress();<br>
         * 2. export() 必须是幂等的,也就是暴露同一个URL的Invoker两次,和暴露一次没有区别<br>
         * 3. 传入的Invoker由框架实现并传入,协议不需要关心<br>
         *
         * @param <T>     服务类型
         * @param invoker 服务调用者
         * @return 暴露服务的引用,用于之后取消暴露
         * @throws RpcException 当暴露服务出错时抛出,比如端口已占用
         */
        @Adaptive
        <T> Exporter<T> export(Invoker<T> invoker) throws RpcException;
    
        /**
         * 引用远程服务: <br>
         * 1. 当用户调用refer()所返回的Invoker对象的invoke()方法时,协议需相应执行同URL远端export()传入的Invoker对象的invoke()方法<br>
         * 2. 返回的Invoker由协议实现,协议通常需要在此Invoker中发送远程请求 <br>
         * 3. 当url中有设置check=false时,连接失败不能抛出异常,并内部自动恢复
         *
         * @param <T>  服务的类型
         * @param type 服务的类
         * @param url  远程服务的URL地址
         * @return invoker 服务的本地代理
         * @throws RpcException 当连接服务提供方失败时抛出
         */
        @Adaptive
        <T> Invoker<T> refer(Class<T> type, URL url) throws RpcException;
    
        /**
         * 销毁协议: <br>
         * 1. 取消该协议所有已经暴露和引用的服务<br>
         * 2. 释放协议所占用的所有资源,比如连接和端口. <br>
         * 3. 协议在释放后,依然能暴露和引用新的服务
         */
        void destroy();
    
    }
  2. AbstractProtocol代码

    public abstract class AbstractProtocol implements Protocol {
    
        protected final Logger logger = LoggerFactory.getLogger(getClass());
        //服务暴露者集合
        protected final Map<String, Exporter<?>> exporterMap = new ConcurrentHashMap<String, Exporter<?>>();
    
        //TODO SOFEREFENCE 服务引用者集合
        protected final Set<Invoker<?>> invokers = new ConcurrentHashSet<Invoker<?>>();
    
        //获取ServiceKey:group0/com.alibaba.dubbo.demo.DemoService:1.0.0:20882
        // group+"/"+serviceName+":"+serviceVersion+":"+port
        protected static String serviceKey(URL url) {
            int port = url.getParameter(Constants.BIND_PORT_KEY, url.getPor
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值