dubbo服务暴露过程
所谓服务暴露最终做的事情:
绑定网络端口,开启serversokect服务以接收外部请求
服务暴露时序图
本地暴露
远程暴露
整体总结
dubbo服务提供者暴露服务的主过程:
首先 ServiceConfig 类拿到对外提供服务的实际类 ref(如:HelloWorldImpl),然后通过 ProxyFactory 类的 getInvoker 方法使用 ref 生成一个 AbstractProxyInvoker 实例,到这一步就完成具体服务到 Invoker 的转化。
接下来就是 Invoker 转换到 Exporter 的过程
Dubbo 处理服务暴露的关键就在 Invoker 转换到 Exporter 的过程
服务发布过程的一些动作
- 暴露本地服务
- 暴露远程服务
- 启动netty
- 连接zookeeper
- 到zookeeper注册
- 监听zookeeper
一句话概括服务暴露:
Service->Invoker->Exporter