•服务提供者在启动的时候,会通过读取一些配置将服务实例化。
•Proxy 封装服务调用接口,方便调用者调用。客户端获取 Proxy 时,可以像调用本地服务一样,调用远程服务。
•Proxy 在封装时,需要调用 Protocol 定义协议格式,例如:Dubbo Protocol。
•将 Proxy 封装成 Invoker,它是真实服务调用的实例。
•将 Invoker 转化成Exporter,Exporter 只是把 Invoker 包装了一层,是为了在注册中心中暴露自己,方便消费者使用。
•将包装好的Exporter 注册到注册中心。
•服务消费者建立好实例,会到服务注册中心订阅服务提供者的元数据。元数据包括服务 IP 和端口以及调用方式(Proxy)。
•消费者会通过获取的 Proxy 进行调用。通过服务提供方包装过程可以知道,Proxy 实际包装了 Invoker 实体,因此需要使用 Invoker 进行调用。
•在 Invoker 调用之前,通过 Directory 获取服务提供者的Invoker 列表。在分布式的服务中有可能出现同一个服务,分布在不同的节点上。
•通过路由规则了解,服务需要从哪些节点获取。
•Invoker 调用过程中,通过 Cluster 进行容错,如果遇到失败策略进行重试。
•调用中,由于多个服务可能会分布到不同的节点,就要通过 LoadBalance 来实现负载均衡。
•Invoker 调用之前还需要经过Filter,它是一个过滤链,用来处理上下文,限流和计数的工作。
•生成过滤以后的 Invoker。
•用 Client 进行数据传输。
•Codec 会根据 Protocol 定义的协议,进行协议的构造。
•构造完成的数据,通过序列化 Serialization 传输给服务提供者。
•Request 已经到达了服务提供者,它会被分配到线程池(ThreadPool)中进行处理。
•Server 拿到请求以后查找对应的 Exporter(包含有 Invoker)。
•由于 Export 也会被 Filter 层层包裹,通过Filter 后获得 Invoker最后,对服务提供者实体进行调用。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。