请介绍一下Dubbo服务消费者调用服务提供者的过程?
整体流程图
通过上面的流程图可以看到,服务消费者通过代理对象Proxy发起远程调用,接着通过网络客户端Client将编码后的请求发送给服务提供方的网络层上,也就是Server。Server在收到请求后,首先要做的事情是对数据包进行解码。然后将解码后的请求发送至分发器Dispatcher,再由分发器将请求派发到指定的线程池上,最后由线程池调用具体的服务。这就是一个远程调用请求的发送与接收过程。
执行流程
1. 生成动态代理类
当调用服务方法的时候,会被InvokerInvocationHandler类的invoke方法拦截。
public Object invoke(Object proxy, Method method,