01、原理
Invoker是实体域,它是 Dubbo 的核心模型,其它模型都向它靠扰,或转换成它,它代表一个可执行体,可向它发起 invoke 调用,它有可能是一个本地的实现,也可能是一个远程的实现,也可能一个集群实现。
【1】、Invocation调用上下文环境
1、String getMethodName() 获取调用方法名。
2、Class< ? >[] getParameterTypes() 获取被调用方法的参数列表(参数类型)
3、Object[] getArguments() 获取被调用方法的参数值数组。
4、Map< String, String> getAttachments() 获取附加属性。
5、String getAttachment(String key) 根据key获取附加属性值。
6、String getAttachment(String key, String defaultValue) 根据key获取附加属性,如果不存在,取默认值。
7、Invoker< ?> getInvoker() 获取当前的invoker。
【2】、Node
1、URL getUrl(); 获取URL,在dubbo中,注册中心、服务提供者、服务消费者、监控中心等都使用URL描述。
2、boolean isAvailable() :判断是否可用。
3、void destroy() :资源销毁。
【3】、 Invoker
1、Class getInterface() :获取服务提供者的接口。
2、Result invoke(Invocation invocation) throws RpcException :调用服务,返回调用结果。
【4】、AbstractInvoker Invoker默认实现(模板类)
该方法主要实现public Result invoke(Invocation inv) throws RpcException,定义执行invoker的基础流程(模板),然后根据不同的实现子类(不同的协议)执行各自个性化的执行任务。其抽象方法:protected abstract Result doInvoke(Invocation invocation) throws Throwable,具体实现将在后文中分析。