dubbo service provider等参数和调用类

// 服务提供者协议配置
        ProtocolConfig protocol = new ProtocolConfig();
        protocol.setName("dubbo");
        protocol.setPort(12345);
        protocol.setThreads(200);

 初始化ioc容器,解析服务提供者标签,AbstractClusterInvoker(FailoverClusterInvoker)(代表一个provider)
 
InvokerInvocationHandler,invoker对象InterceptorInvokerNodeAbstractCluster内部类),传入一个接口调用对象RpcInvocation,返回一个异步结果对象AsyncRpcResult,
构造方法创建intereptor,ConsumerContextClusterInterceptor(消费者上下文集群拦截器,代表接口调用前后过程清理上下文并把监听调用应答结果),next参数是ZoneAwareClusterInvoker,然后走到FailoverClusterInvoker,是provider对象。RegistryDirectory$InvokerDelegate,ListenerInvokerWrapper,AysncToSyncInvoker(asyncResult.get(2147482647L,TimeUnit.MILLSECONDES)同步模式会一直等待,这个超时时间太大了),
DubboInvoker(ExecutorService线程池,在线程池中通过客户端调接口, ExexutorService executor = this.getCallbackExecutor(this.getUrl(),inv); 
CompletableFuture<AppResponse> appResponseFuture =  currentClient.request(inv,timeout,executor).thenApply((obj)->{
return (AppResponse)obj;})
),ReferenceCountExchangeClient客户端,HeaderExchangeChannel类,执行接口请求,其中chnnel是netty的channel。把线程池给DefaultFuture,在其中newFuture方法中执行
executor.setWaitingFuture(future);
共用channel连接,用channel和ExexutorService线程池创建CompletableFuture,
然后channel调用send方法(真实发起请求),然后用CompletableFuture等待channel结果。
所有接口调用都共用一个连接,每个调用创建一个channel.
channel先执行发送,创建一个未来的结果conpletableFuture对象,

在ThreadLess类中执行了任务后,调HeaderExchangeHandler.received,处理消息,
调DefaultFuture.received方法。

在异步线程中,netty框架的abastractEventExecutor执行回调接口,收到应答事件,调headerExchangeHandler.sent方法,表示已经收到channel的发送结果。
channel的事件顺序, 发送,已发送,已应答。
channelEventRunnable-已发送,AllChannelHandler的received方法收到应答报文。在这里获取线程池,然后在线程池之中处理应答报文。
调headerExchangeHandler的received方法处理结果。
channelEventRunnable的run方法处理结果,其中decodehandler解码,走到了headerExchangeHandler的received方法,调DefaultFuture.received方法,然后调CompetableFuture的complete方法,到此结束。


DefaultExecutorResository.getExecutor(URL url),线程池允许最大int最大值个线程。
ComppletableFuture作为执行结果返回,从中获取结果。

AsyncRpcResult(代表接口调用异步结果AsyncRpcResultRpcInvocation(代表一个接口调用对象,保存了相关参数)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值