ProtocolConfig protocol = new ProtocolConfig();
protocol.setName("dubbo");
protocol.setPort(12345);
protocol.setThreads(200);
初始化ioc容器,解析服务提供者标签,AbstractClusterInvoker(FailoverClusterInvoker)(代表一个provider)
InvokerInvocationHandler,invoker对象InterceptorInvokerNode(AbstractCluster内部类),传入一个接口调用对象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(代表接口调用异步结果AsyncRpcResult)
RpcInvocation(代表一个接口调用对象,保存了相关参数)