博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
rpc服务和http服务的区别
阅读量:4702 次
发布时间:2019-06-09

本文共 1014 字,大约阅读时间需要 3 分钟。

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

你可能感兴趣的文章
使用 string 的一些规则
查看>>
gnome-terminal的一些调整
查看>>
POJ 1273 Drainage Ditches
查看>>
POJ 1733 Parity game
查看>>
js晋级篇——前端内存泄漏探讨
查看>>
Drupal 出错的解决办法
查看>>
js正则
查看>>
thrift源码阅读笔记
查看>>
iOS UI基础-4.0应用程序管理
查看>>
在CentOS 6.4 x86_32中使用Rhythmbox听MP3
查看>>
sys模块
查看>>
BZOJ3073 : [Pa2011]Journeys
查看>>
BZOJ2213 : [Poi2011]Difference
查看>>
聊聊javascript的事件
查看>>
对象基础
查看>>
【MySQL比知必会】第九章 使用正则表达式进行搜索
查看>>
查看Oracle数据库名和实例名的命令
查看>>
20155302 2016-2017-2 《Java程序设计》第4周总结
查看>>
java Html 转 PDF
查看>>
C++ 标准库 permutation
查看>>