09-Dubbo中的Invoker的原理与实例

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,具体实现将在后文中分析。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值