• 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这样的协议等。

  • 相关阅读:
    [LeetCode] Unique Substrings in Wraparound String 封装字符串中的独特子字符串
    [LeetCode] Number of Segments in a String 字符串中的分段数量
    [LintCode] Longest Common Prefix 最长共同前缀
    [LintCode] Product of Array Except Self 除本身之外的数组之积
    [LintCode] Best Time to Buy and Sell Stock 买卖股票的最佳时间
    [LintCode] Sort List 链表排序
    [LintCode] Find Peak Element 求数组的峰值
    [LintCode] Container With Most Water 装最多水的容器
    [LintCode] Linked List Cycle 单链表中的环
    [LeetCode] 465. Optimal Account Balancing 最优账户平衡
  • 原文地址:https://www.cnblogs.com/beanjk/p/11274480.html
Copyright © 2020-2023  润新知