rpc服务和http服务的区别

rpc服务和http服务的区别

1、传输协议
  http服务是基于http协议
  rpc服务是基于tcp/ip协议
2、传输效率
  RPC,使用自定义的TCP协议,可以让请求报文体积更小,提高传输效率
  HTTP,如果是基于HTTP1.1的协议,请求中会包含很多无用的内容,如果是基于HTTP2.0,那么简单的封装以下是可以作为一个RPC来使用的
3、性能消耗,主要在于序列化和反序列化的耗时
  RPC,可以基于thrift实现高效的二进制传输
  HTTP,大部分是通过json来实现的,字节大小和序列化耗时都比thrift要更消耗性能
4、负载均衡
  RPC,基本都自带了负载均衡策略
  HTTP,需要配置Nginx,HAProxy来实现
5、服务治理(下游服务新增,重启,下线时如何不影响上游调用者)
  RPC,能做到自动通知,不影响上游
  HTTP,需要事先通知,修改Nginx/HAProxy配置


总结:RPC主要用于公司内部的服务调用,性能消耗低,传输效率高,服务治理方便。
HTTP主要用于对外的异构环境,浏览器接口调用,APP接口调用,第三方接口调用等。

流行的RPC框架:
  Dubbo是阿里集团开源的一个极为出名的RPC框架。
比如我们有一个处理订单的系统服务,先声明它的所有的接口(这里就是具体指Java中的interface),然后将整个项目打包为一个
jar包,服务端这边引入这个二方库,然后实现相应的功能,客户端这边也只需要引入这个二方库即可调用了。为什么这么做?主要是为了减少客户端这边的
jar包大小,因为每一次打包发布的时候,jar包太多总是会影响效率。另外也是将客户端和服务端解耦,提高代码的可移植性。


http协议和tcp协议的区别
1、TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。
2、术语TCP/IP代表传输控制协议/网际协议,指的是一系列协议。“IP”代表网际协议,TCP和UDP使用该协议从一个网络传送数据包到另一个网络。把IP想像成一种高速公路,
它允许其它协议在上面行驶并找到到其它电脑的出口。TCP和UDP是高速公路上的“卡车”,它们携带的货物就是像HTTP,文件传输协议FTP这样的协议等。

原文地址:https://www.cnblogs.com/beanjk/p/11274480.html