当前位置: 移动技术网 > IT编程>软件设计>架构 > NetCore Netty 框架 BT.Netty.RPC 系列随讲 —(前序) REST API 与 RPC 经典网络基础服务架构

NetCore Netty 框架 BT.Netty.RPC 系列随讲 —(前序) REST API 与 RPC 经典网络基础服务架构

2019年05月29日  | 移动技术网IT编程  | 我要评论

        在服务体系架构内,我们所知道的,有两种请求模型: http 请求模型,以及 rpc 请求模型。因此,在一个互联网请求模型架构上,都是这两种的请求模型的向互组合.

 

下面给出两种常见的互联网经典基础架构图:

 

  一:外:http  内:rpc                                                                        二:外:http 内: http

 

rpc                                http     

 

下面讲讲这两种网络架构的优缺点: 这里只发表我个人的看法。如果各位大神,如果有其他看法的话,那么也可随意留言:

 

共同点: http 主外,http 主外有个两个最大的优点

 

    1:对于前端框架的易用性和对异构系统的对接性更较强. 也就是说http 的跨平台性跟跨协作方面来的更  加合适, 原因为啥:原因 就是大部分同学都知道http 协议嘛。

 

     2:对于http 来说,外部的客户数量是不可控的,http 的短链接,就很好的解决这方面服务的线程资源占用的问题。 http 原本初衷就是一次请求,一个线程,一次会话的模型。 而 rpc ,则是长连接模型。客户端不活动,也会占用服务的tcp  线程连接数。

 

两张图的不同之处在于:

 

图一:内部服务集群采用rpc,   图二内部集群采用http。 这两者都有存在大厂中在, 问题仁者见仁,智者见智 

 

内部采用rpc的优点:效率高,传输快. 而rpc 为什么会效率高,传输快: 这就讲下rpc 与http 本质上的区别:

 

 http协议是应用层协议,http协议位于tcp/ip协议栈的应用层。基于http协议的客户/服务器模式的信息交换过程,分四个过程:建立连接、发送请求信息、发送响应信息、关闭连接。

 

而 rpc(remote procedure call protocol) 远过程调用协议,在osi网络通信模型中,rpc跨越了传输层和应用层。rpc信息协议由两个不同结构组成:调用信息和答复信息. 因此 在rpc 的协议包一般情况下都是自己定义,自己封装,封包。正是因为rpc 穿越了osi 的 传输层与应用层,使得它的效率更高,传输更快,也是正是应为rpc 的 协议包可以自由定义,

 

因此,它的网络传输载请求单位体积就可以变得非常小, 并不像http协议包臃肿肥大。但是也正因为如此,rpc 本质的维护成本以及开发成本来的更高。从另外个角度讲,http 的对于公司角度而言:服务的迭代以及开发成本来的更加快捷,方便。

 

    个人在内部局域网内服务群集方面也是采用 http ( 考虑到公司的开发协作成本方面,还有老服务遗留下来的历史原因)。  但是.netcore netty 还是一个非常棒的实现rpc 底层框架。因此还是值得我们去发现。

 

 

 

 

 

 

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网