dubbo服务暴露-本地暴露(二)

本地暴露

ServiceConfig类:

private void doExportUrlsFor1Protocol(ProtocolConfig protocolConfig, List<URL> registryURLs) {
...
if (!Constants.SCOPE_NONE.toString().equalsIgnoreCase(scope)) {
	if (!Constants.SCOPE_REMOTE.toString().equalsIgnoreCase(scope)) {
		//本地暴露
	  	exportLocal(url);
	 }
 }
...
}

我们进入这个方法:
在这里插入图片描述先判断/如果 URL 的协议头等于 injvm,说明已经导出到本地了,无需再次导出
我们先看proxyFactory.getInvoker()方法,它是生成一个Invoker对象,注意看下结果,导出本地服务的Invoker是injvm://127.0.0.1…
injvm://......接下开我们看protocol.export()的实现,进入InjvmProtocol类中

@Override
    public <T> Exporter<T> export(Invoker<T> invoker) throws RpcException {
        return new InjvmExporter<T>(invoker, invoker.getUrl().getServiceKey(), exporterMap);
    }

在这个构造器中,利用exporterMap缓存了exporter。

总结

本地暴露做了哪些事情:

exportLocal 方法比较简单,首先根据 URL 协议头决定是否导出服务。若需导出,则创建一个新的 URL 并将协议头、主机名以及端口设置成新的值。然后创建 Invoker,并调用 InjvmProtocol 的 export 方法导出服务,就是创建了一个 InjvmExporter对象,利用exporterMap缓存了exporter。

思考下为什么需要本地暴露

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值