UDS怎么看苹果id账户余额中的broker ID指的是什么可以理解为翻译.希望准确一点

你的题目是RPC框架首先了解什么叫RPC,为什么要RPCRPC是指远程过程调用,也就是说两台服务器AB,一个应用部署在A服务器上想要调用B服务器上应用提供的函数/方法,由于不茬一个内存空间不能直接调用,需要通过网络来表达调用的语义和传达调用的数据

比如说,一个方法可能是这样定义的:

  • 首先要解決通讯的问题,主要是通过在客户端和服务器之间建立TCP连接远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接调用结束后就断掉,也可以是长连接多个远程过程调用共享同一个连接。
  • 第二要解决寻址的问题,也就是说A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口方法的名称名称是什么,这样才能完成调用比如基于Web服务协议棧的RPC,就要提供一个endpoint URI或者是从UDDI服务上查找。如果是RMI调用的话还需要一个RMI Registry来注册服务的地址。
  • 第三当A服务器上的应用发起远程过程调鼡时,方法的参数需要通过底层的网络协议如TCP传递到B服务器由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器
  • 第四,B服务器收到请求后需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值
  • 第五,返回值還要发送回服务器A上的应用也要经过序列化的方式发送,服务器A接到后再反序列化,恢复为内存中的表达方式交给A服务器上的应用

為什么RPC呢?就是无法在一个进程内甚至一个计算机内通过本地调用的方式完成的需求,比如比如不同的系统间的通讯甚至不同的组织間的通讯。由于计算能力需要横向扩展需要在多台机器组成的集群上部署应用,

关于Netty而Netty框架不局限于RPC更多的是作为一种网络协议的实現框架,比如HTTP由于RPC需要高效的网络通信,就可能选择以Netty作为基础除了网络通信,RPC还需要有比较高效的序列化框架以及一种寻址方式。如果是带会话(状态)的RPC调用还需要有会话和状态保持的功能。

大体上来说Netty就是提供一种事件驱动的,责任链式(也可以说是流水線)的网络协议实现方式网络协议包含很多层次,很多部分组成如传输层协议,编码解码压缩解压,身份认证加密解密,请求的處理逻辑怎么能够更好的复用,扩展业界通用的方法就是责任链,

一个请求应答网络交互通常包含两条链一条链(Upstream)是从传输层,經过一系列步骤如身份认证,解密日志,流控最后到达业务层,一条链(DownStream)是业务层返回后又经过一系列步骤,如加密等又回箌传输层。


这样每一层都有一个处理接口都可以进行不同的操作,比如身份认证加解密,日志流控,将不同的处理实现像拼积木那樣插接起来就可以实现一个网络协议了(快速开发)每一层都有自己的实现,上层不需要关注面向网络的操作(可维护)Netty已经提供了佷多实现。 当然Netty还有许多好处比如对非阻塞IO(NIO)的支持,比如在链上传递时最大程度的减少buffer的copy(高性能)

我要回帖

更多关于 怎么看苹果id账户余额 的文章

 

随机推荐