dubbo工做原理面试
第一层:service层,接口层,给服务提供者和消费者来实现的缓存
第二层:config层,配置层,主要是对dubbo进行各类配置的网络
第三层:proxy层,服务代理层,透明生成客户端的stub和服务端的skeleton负载均衡
第四层:registry层,服务注册层,负责服务的注册与发现异步
第五层:cluster层,集群层,封装多个服务提供者的路由以及负载均衡,将多个实例组合成一个服务ide
第六层:monitor层,监控层,对rpc接口的调用次数和调用时间进行监控spa
第七层:protocol层,远程调用层,封装rpc调用代理
第八层:exchange层,信息交换层,封装请求响应模式,同步转异步netty
第九层:transport层,网络传输层,抽象mina和netty为统一接口blog
第十层:serialize层,数据序列化层
工做流程:
第一步,provider向注册中心去注册
第二步,consumer从注册中心订阅服务,注册中心会通知consumer注册好的服务
第三步,consumer调用provider
第四步,consumer和provider都异步的通知监控中心
注册中心挂了能够继续通讯吗
能够,由于刚开始初始化的时候,consumer会将provider的地址等信息拉取到本地缓存,因此注册中心挂了能够继续通讯
转自:中华石杉Java工程师面试突击