出处: 谁能用通俗的语言解释一下什么是 RPC 框架?

知乎:

  问题:了解到最近 Java 的 Netty 很火,只知道它是这样类型的一种框架。想了解一下它主要用于解决了什么问题?适用于什么样的场景?

答:

关于RPC

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

  比如说,一个方法可能是这样定义的:Employee getEmployeeByName(String fullName)

 那么:

  首先,要解决通讯的问题,主要是通过在客户端和服务器之间建立TCP连接,远程过程调用的所有交换的数据都在这个连接里传输。连接可以是按需连接,调用结束后就断掉,也可以是长连接,多个远程过程调用共享同一个连接。

  第二,要解决寻址的问题,也就是说,A服务器上的应用怎么告诉底层的RPC框架,如何连接到B服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如服务器(如主机或IP地址)以及特定的端口,方法的名称名称是什么,这样才能完成调用。比如RMI调用的话,还需要一个RMI Registry来注册服务的地址。

  第三,当A服务器上的应用发起远程过程调用时,方法的参数需要通过底层的网络协议如TCP传递到B服务器,由于网络协议是基于二进制的,内存中的参数的值要序列化成二进制的形式,也就是序列化(Serialize)或编组(marshal),通过寻址和传输将序列化的二进制发送给B服务器。

  第四,B服务器收到请求后,需要对参数进行反序列化(序列化的逆操作),恢复为内存中的表达方式,然后找到对应的方法(寻址的一部分)进行本地调用,然后得到返回值。

  第五,返回值还要发送回服务器A上的应用,也要经过序列化的方式发送,服务器A接到后,再反序列化,恢复为内存中的表达方式,交给A服务器上的应用

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

  RPC的协议有很多,比如最早的CORBA,Java RMI,Web Service的RPC风格,Hessian,Thrift,甚至Rest API。

关于Netty

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

  大体上来说,Netty就是提供一种事件驱动的,责任链式(也可以说是流水线)的网络协议实现方式。网络协议包含很多层次,很多部分组成,如传输层协议,编码解码,压缩解压,身份认证,加密解密,请求的处理逻辑,怎么能够更好的复用,扩展,业界通用的方法就是责任链,一个请求应答网络交互通常包含两条链,一条链(Upstream)是从传输层,经过一系列步骤,如身份认证,解密,日志,流控,最后到达业务层,一条链(DownStream)是业务层返回后,又经过一系列步骤,如加密等,又回到传输层。

  这样每一层都有一个处理接口,都可以进行不同的操作,比如身份认证,加解密,日志,流控,将不同的处理实现像拼积木那样插接起来就可以实现一个网络协议了(快速开发)。每一层都有自己的实现,上层不需要关注面向网络的操作(可维护)。Netty已经提供了很多实现。

当然Netty还有许多好处,比如对非阻塞IO(NIO)的支持,比如在链上传递时最大程度的减少buffer的copy(高性能)。

最新文章

  1. 关于java中的异常问题 1
  2. Android中Service(服务)详解
  3. 在Vista或更高版本Windows系统中, 获取超大图标的办法
  4. SQL Server 之登录
  5. 分布式文件系统 - FastDFS
  6. mysql 常用操作
  7. windows平台vhd磁盘文件挂载
  8. _int64、long long 的区别
  9. php sprintf函数
  10. 将Error异常日志从普通日志中剥离
  11. ssi服务器端指令详解(shtml)
  12. j2e中操作EXCEL
  13. R︱shiny实现交互式界面布置与搭建(案例讲解+学习笔记)
  14. ARM Linux内核Input输入子系统浅解
  15. 获取choice的value
  16. OS模块常用方法
  17. Python交互图表可视化Bokeh:7. 工具栏
  18. codeforces-1102e
  19. swift重写导航控制器类的 initialize 方法
  20. js将对象数组按照自定义规则排序

热门文章

  1. nmap脚本nse的使用
  2. Spring boot 读取resource目录下的文件
  3. 【面试】Redis
  4. idea如果发生@override is not allowed when implement 错误,可以在Project Structure-Modules中更改Language level,设置为6以上的。
  5. TensorFlow 学习(2)——正式起步
  6. leetcode73矩阵置零
  7. RN中webview的一些思考
  8. C实现通讯录管理系统(亮点:纯链表实现、子串匹配,文件读写)
  9. javascript的变量声明和数据类型
  10. SQL学习(六)select into:复制表信息