哈喽大家好,我是咸鱼

随着互联网技术的发展,分布式架构越来越被人们所采用。在分布式架构下,为了实现复杂的业务逻辑,应用程序需要分布式通信实现远程调用

而这时候就需要一种协议来支持远程过程调用,以便实现不同应用程序之间的数据交换和信息传递。其中常用的协议包括 HTTP 协议和 RPC 协议

HTTP 协议和 RPC 协议都是用于计算机之间进行通信的协议。那么小伙伴们有没有想过它们之间有什么区别呢?有了HTTP为什么还要RPC呢?

为了解答上面的疑问,我们先从这两个协议的介绍开始

HTTP 和 RPC

  • HTTP

学过计算机网络的小伙伴们相信对下面这段话再熟悉不过了:

HTTP(HyperText Transfer Protocol,超文本传输协议)协议,主要用于在 Web 浏览器和 Web 服务器(B/S架构)之间传输超文本标记语言(HTML)文件,支持客户端和服务器之间的通信

HTTP 协议是网络传输协议中应用最为广泛的一种,HTTP 协议基于请求/响应模型,通过在客户端和服务器之间交换请求和响应来传输数据。

它简单、灵活、可扩展,而且最重要的是——它是一种无状态协议,也就是说,每次客户端和服务器之间交换请求和响应时,HTTP协议都是一张白纸,不会记住之前的任何信息

而无状态协议重要的一点优势是可靠,即使某个请求失败或者丢失,也不会影响到其他请求的处理

HTTP 协议使用文本格式进行传输,方便开发人员去阅读和调试,又因具有可跨平台、可扩展、可缓存、可重用等优点被广泛应用于 Web 开发中,常用于网页访问、图片加载等场景

看到这里,小伙伴可能会想,HTTP 这么神,它真的就一点缺点没有吗?当然肯定是有的

前面我们说到 HTTP 协议是无状态的,也就是说每次请求和响应之间是没有关联的,服务器不会记住之前的任何信息,所以会导致每次请求都要重新建立连接

在处理一些长连接或高并发的场景时,每次请求都需要重新建立连接,而这个过程不但会增加了网络开销和延迟,还会消耗服务器的资源,从而降低了效率。如果使用有状态的协议,服务器可以记住之前的信息,避免了重复建立连接的过程

除此之外,因为 HTTP 协议最初设计的目的是为了在客户端和服务器之间传输 HTML 文档,即数据传输格式是基于文本的

所以说 HTTP 协议不支持类型化的数据传输和自定义协议扩展,请求和响应的格式是固定的,这就导致了它不能很好地支持自定义数据结构和复杂逻辑

简单来说,HTTP 协议有点“死板”

  • RPC

RPC(Remote Procedure Call,远程过程调用)协议是一种进程间通信协议,用于实现分布式应用程序之间的远程调用,使得不同的应用程序可以像调用本地程序一样调用远程程序

RPC 协议基于函数调用模型。在 RPC 协议中,客户端调用远程服务器上的函数时,会将参数打包成消息并发送给服务器,服务器接收到消息后,解包参数并执行相应的函数,最后将结果打包成消息并发送回客户端、

这这个过程对于客户端来说是透明的,就像调用本地函数一样,即 RPC 可以实现在不同的进程或不同的机器之间进行函数调用

它具有网络传输速度快、协议扩展性好等优点(因为采用了二进制数据传输格式,相对于HTTP等基于文本的协议,二进制格式传输数据更加高效)。不但如此,RPC 的设计初衷就是支持多种数据格式和传输协议,这使得它可以很好地支持复杂的数据结构和逻辑

此外,RPC 协议可以使用更高效的编码和传输协议,还可以使用异步调用来提高响应速度

我们常说,世上没有完美的东西,HTTP 如此,RPC 也是如此

与 HTTP 相比,RPC 更加复杂。为了实现 RPC 协议的设计目标(高效、灵活和可扩展),它需要定义更多的接口和协议,同时需要更多的配置和管理。当然这会提高开发和运维的难度

为了支持跨语言、跨平台的远程调用,RPC 通常不包含安全机制。如果不采取额外的安全措施,就有可能存在身份伪造、数据篡改、拒绝服务等安全问题

为了保护网络安全,我们可以在 RPC 中实现额外的安全措施:

  1. 例如使用SSL/TLS协议进行加密通信
  2. 使用数字证书进行身份验证
  3. 使用访问控制列表进行授权
  4. 进行安全审计和漏洞扫描

前面我们说到,RPC 通常采用二进制数据传输格式,而不是基于文本的格式。二进制格式虽然传输效率高,但是需要额外的计算资源来序列化和反序列化参数和返回值

在 RPC 中,客户端和服务器之间需要将参数和返回值打包成二进制数据,并在网络上传输。这个过程需要将参数和返回值转换为二进制格式,并进行压缩和编码,以减少数据传输量

对于接收方,需要将接收到的二进制数据解码并转换为原始数据格式。这个过程需要消耗额外的计算资源

因此,RPC需要额外的网络带宽和计算资源来序列化和反序列化参数和返回值

HTTP 和 RPC 的区别

  1. 目的不同

HTTP 是一种无状态的协议,它的主要目的在客户端和服务器之间交换请求和响应来传输文本内容

RPC 是一种有状态的协议,它的主要目的是在客户端和服务器之间传递信息并调用远程函数

  1. 传输方式不同

HTTP 使用文本(如 HTML、XML、JSON等)作为载体,并且使用明文传输

RPC可以使用多种格式传输(例如二进制格式),并且可以使用额外的安全加密技术保证传输安全性

  1. 通信方式不同

HTTP 使用的是请求/响应模型,客户端向服务器发送请求并等待响应。客户端发送一个请求,服务器返回一个响应

RPC 使用的是调用/返回模型,客户端调用服务器上的远程函数并等待返回结果。RPC 支持多种不同的调用方式,如同步调用、异步调用、流式调用等

有了 HTTP 为什么还要 RPC?

虽然 HTTP 已经成为了网络通信的重要标准之一而且被广泛应用于互联网上的各种场景,但是在某些情况下,它并不能满足用户的需求

例如在一些复杂的分布式应用场景下(分布式系统中的服务调用、微服务架构中的服务间通信等),RPC 协议要比 HTTP 协议更适合

咸鱼将从以下几点来阐述一下 RPC 为什么更适合复杂的分布式应用场景

从时效性度来看

  • HTTP 协议的数据格式有一定的局限性,比如只能传输文本,传输效率低下
  • HTTP协议是基于请求/响应模型,每次请求都需要建立一个新的连接,这样会增加网络开销
  • 相比于 HTTP 协议,RPC 协议通常使用二进制数据格式进行传输,通常具有更高的传输效率和更低的网络延迟
  • 相比于 HTTP 协议,RRPC协议还支持异步调用和批量调用等高级特性,可以提高系统的性能和吞吐量

从安全性来看

  • HTTP 是一种文本协议,数据传输使用的是明文,这样就容易被中间人窃听或者篡改数据(不过可以使用SSL/TLS 协议对数据进行加密和认证)
  • 相比于 HTTP 协议,RPC 支持传输各种类型的数据(比如二进制),可以更快灵活地传输大量数据,并且也可以加密传输以保证安全性

从场景复杂度来看

  • 在复杂的业务逻辑和数据结构场景下,通常需要进行多次请求和响应操作,而 HTTP 作为无状态协议无法保持会话状态,每次请求和响应都需要重新建立连接和传输数据,这会导致网络延迟和性能下降
  • HTTP协议的请求和响应通常是基于文本或二进制数据格式,无法直接支持复杂的数据结构,例如对象、数组、枚举等
  • 相比于 HTTP 协议,RPC 是一种有状态协议,而且 RPC 可以通过定义接口和方法来封装业务逻辑,使得客户端可以通过简单的调用来完成复杂的操作
  • 相比于 HTTP 协议,RPC协议是一种面向对象的协议,它可以直接支持复杂的数据结构,例如对象、数组、枚举等

为什么有了 HTTP 还要 RPC的更多相关文章

  1. 有了HTTP,为啥还要用RPC

    既然有 HTTP 请求,为什么还要用 RPC 调用? 一直以来都没有深究过RPC和HTTP的区别,不都是写一个服务然后在客户端调用么? HTTP和RPC最本质的区别,就是 RPC 主要是基于 TCP/ ...

  2. 从 BIO、NIO 聊到 Netty,最后还要实现个 RPC 框架!

    大家好,我是 「后端技术进阶」 作者,一个热爱技术的少年. 觉得不错的话,欢迎 star!ღ( ´・ᴗ・` )比心 Netty 从入门到实战系列文章地址:https://github.com/Snai ...

  3. 既然有 HTTP 请求,为什么还要用 RPC 调用?

    首先,实名赞扬题主的问题.这个问题非常好. 其次,实名反对各个上来就讲RPC好而HTTP不好的答案.因为,题主的观点非常对. HTTP协议,以其中的Restful规范为代表,其优势很大.它可读性好,且 ...

  4. 谈谈如何使用Netty开发实现高性能的RPC服务器

    RPC(Remote Procedure Call Protocol)远程过程调用协议,它是一种通过网络,从远程计算机程序上请求服务,而不必了解底层网络技术的协议.说的再直白一点,就是客户端在不必知道 ...

  5. 游戏编程系列[2]--游戏编程中RPC与OpLog协议的结合--序

    在系列[1]中,我们展示了RPC调用协议的定义以及演示,通过方法定义以及协议约定,进行了协议约定以及调用过程的约定.然而,实际上在游戏中,调用过程之后,需要传输相对多的数据给服务端. 常用场景,客户端 ...

  6. RPC远程过程调用学习之路(一):用最原始代码还原PRC框架

    RPC: Remote Procedure Call 远程过程调用,即业务的具体实现不是在自己系统中,需要从其他系统中进行调用实现,所以在系统间进行数据交互时经常使用. rpc的实现方式有很多,可以通 ...

  7. spider RPC开发指南

    协议与兼容性 spider使用java语言开发,使用Spring作为IoC容器,采用TCP/IP协议,在此基础上,结合SaaS系统模式的特性进行针对性和重点设计,以更加灵活和高效的满足多租户系统.高可 ...

  8. 基于netty轻量的高性能分布式RPC服务框架forest<上篇>

    工作几年,用过不不少RPC框架,也算是读过一些RPC源码.之前也撸过几次RPC框架,但是不断的被自己否定,最近终于又撸了一个,希望能够不断迭代出自己喜欢的样子. 顺便也记录一下撸RPC的过程,一来作为 ...

  9. rpc框架之 thrift连接池实现

    接前一篇rpc框架之HA/负载均衡构架设计 继续,写了一个简单的thrift 连接池: 先做点准备工作: package yjmyzz; public class ServerInfo { publi ...

  10. rpc框架之 avro 学习 2 - 高效的序列化

    同一类框架,后出现的总会吸收之前框架的优点,然后加以改进,avro在序列化方面相对thrift就是一个很好的例子.借用Apache Avro 与 Thrift 比较 一文中的几张图来说明一下,avro ...

随机推荐

  1. python pandas库总结-数据分析和操作工具

    参考:https://pandas.pydata.org/ Input/output相关函数 pandas.read_excel-将Excel文件读入pandas数据框 支持读取xls, xlsx, ...

  2. 小白都能看懂得Xxl-job安装教程

    大家好,我是咔咔 不期速成,日拱一卒 一.背景 在平时的业务场景中,经常有一些场景需要使用定时任务,比如: 某个时间点发送优惠券 发送短信等等. 批量处理数据:批量统计上个月的账单,统计上个月销售数据 ...

  3. SpringBoot——静态资源及原理

    一.使用 SpringBoot 的步骤 [1]创建 SpringBoot应用,选中自己需要的模块.[2]SpringBoot 已经默认将这些场景配置好,只需要在配置文件中指定少量配置就可以运行起来.[ ...

  4. Mybatis模糊查询的两种方式

    第一种 使用 || 字符: ** ** 第二种 使用 CONCAT 函数: ** ** 温馨提醒: 当然你也可以使用 $符 ,但是这种方式会导致不安全,让非法分子有机可寻,轻则数据库瘫痪,重则数据泄露 ...

  5. 基于开源的 ChatGPT Web UI 项目,快速构建属于自己的 ChatGPT 站点

    作为一个技术博主,了不起比较喜欢各种折腾,之前给大家介绍过 ChatGPT 接入微信,钉钉和知识星球(如果没看过的可以翻翻前面的文章),最近再看开源项目的时候,发现了一个 ChatGPT Web UI ...

  6. 如何申请 Azure OpenAI

    一.前言 众所周知 OpenAI ChatGPT 是不对中国开放的,包括香港.就最近一个月的情况来看,陆续有 API 调用被限制.大规模账号封禁.关闭注册.无法直接使用银联支付(国内信用卡)等等,使用 ...

  7. ChatGPT推荐最常用的自动化测试、性能、安全测试工具!

    ChatGPT是一种当前被广泛关注的人工智能技术,它具备生成自然语言的能力,能够完成一些简单的文本生成.对话交互等任务.ChatGPT 算法的出现,打破了以前自然语言处理的瓶颈,使得机器具备了更加贴合 ...

  8. Distinctive Image Features from Scale-Invariant Keypoints 论文解读

    Distinctive Image Features from Scale-Invariant Keypoints 论文解读 著名的SIFT local feature提取方法 Scale-space ...

  9. vue之字符串的方法

    目录 简介 indexOf方法 简介 本文会把遇到的字符串的方法慢慢补充进来 indexOf方法 indexOf方法判断字符串是否包含另一个字符串 判断结果如果包含返回的是索引,如果不包含,则返回-1 ...

  10. 五月十三号Java基础知识点

    1.getFields()和getMethods()方法获得权限为public的本类的以及父类继承的成员变量和成员方法2.getDeclaredFields()和getDeclaredMethods( ...