【知识拓展】HTTP、WebSocket 和 RPC:区别与使用场景详解

        在工作中,HTTP、WebSocket 和 RPC 是三种常见的协议或通信方式,根据资料查阅,本文主要记录它们的区别及其适用的使用场景

HTTP(超文本传输协议)

概述

HTTP(Hypertext Transfer Protocol)是一种用于分布式、协作、超媒体信息系统的应用层协议。它是万维网(WWW)的基础,通过它,客户端(通常是浏览器)和服务器之间可以进行通信。

特性
  • 无状态:每个请求都是独立的,服务器不会保留任何会话信息。
  • 请求-响应模式:客户端发起请求,服务器返回响应。
  • 文本协议:数据以纯文本形式传输,包括头部和主体。
  • 标准端口:默认使用端口80(HTTP)和443(HTTPS)。
使用场景
  • 网页浏览:用户通过浏览器请求网页资源(HTML、CSS、JavaScript、图片等),服务器响应这些资源。
  • API调用:客户端通过HTTP请求与服务器交互数据(例如RESTful API)。
  • 文件下载:用户通过HTTP下载文件,如软件、文档等。

WebSocket协议

概述

WebSocket是一种在单个TCP连接上进行全双工通信的协议。它由HTML5引入,旨在解决HTTP的实时性和效率问题。

特性
  • 全双工通信:允许客户端和服务器同时发送和接收消息。
  • 持久连接:连接一旦建立,将保持打开状态,直到显式关闭。
  • 低开销:较少的头部信息,使得数据传输效率更高。
  • 实时性:非常适合需要低延迟和实时更新的应用。
使用场景
  • 实时聊天应用:如即时通讯工具(微信、WhatsApp)。
  • 在线游戏:需要低延迟和实时交互的多人在线游戏。
  • 实时数据推送:如股票行情、体育比分更新。
  • 协作编辑工具:如Google Docs,多个用户同时编辑文档时的实时同步。

RPC(远程过程调用)

概述

RPC(Remote Procedure Call)是指远程过程调用,也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。

RPC的核心并不在于使用什么协议。目的是让你在本地调用远程的方法,而对你来说这个调用是透明的,你并不知道这个调用的方法是部署哪里。

通过RPC能解耦服务,这才是使用RPC的真正目的。RPC的原理主要用到了动态代理模式,至于http协议,只是传输协议而已。简单的实现可以参考spring remoting,复杂的实现可以参考dubbo。

特性
  • 透明性:调用远程服务的方式与本地调用几乎无异,隐藏了底层通信细节。
  • 协议无关:可以基于多种协议实现(如HTTP、TCP、UDP)。
  • 同步/异步:可以支持同步调用和异步调用。
  • 数据序列化:通常使用JSON、XML或二进制格式进行数据编码和解码。
使用场景
  • 分布式系统:如微服务架构中不同服务之间的通信。
  • 跨语言调用:不同编程语言编写的服务之间进行通信。
  • 高性能服务:需要高效、低延迟的远程服务调用,如金融系统的交易处理。

详细比较

特性HTTPWebSocketRPC
通信模式请求-响应全双工通信请求-响应(可以是同步或异步)
连接管理每次请求建立新连接(HTTP/1.1支持持久连接)持久连接持久连接(取决于底层协议)
数据传输文本或二进制文本或二进制序列化后的数据(JSON、XML、二进制)
实时性较差优秀良好
使用场景网页浏览、API调用、文件下载实时聊天、在线游戏、数据推送分布式系统、跨语言调用、高性能服务

使用场景详解

HTTP 使用场景

HTTP协议是互联网的基石,主要用于浏览器与服务器之间的通信。典型的使用场景包括:

  • 网页浏览:用户通过浏览器访问网页,浏览器向服务器发送HTTP请求,服务器返回HTML、CSS、JS等资源。
  • RESTful API:在前后端分离的架构中,前端通过HTTP请求与后端API服务器进行数据交互。
  • 文件下载:用户通过HTTP协议下载各种类型的文件,如文档、图片、软件等。
WebSocket 使用场景

WebSocket协议适用于需要实时数据传输的应用场景。典型的使用场景包括:

  • 即时通讯:如聊天应用和社交媒体消息系统,要求低延迟和实时消息传输。
  • 实时更新:如股票市场行情、体育比分更新,需要实时推送数据给用户。
  • 在线协作:如多人同时编辑文档、代码,实时同步用户操作。
  • 在线游戏:需要低延迟的实时交互游戏,如多人在线竞技游戏。
RPC 使用场景

RPC协议用于分布式系统中远程服务调用。典型的使用场景包括:

  • 微服务架构:在微服务架构中,各个服务之间需要通过RPC进行通信和数据交互。
  • 跨语言调用:不同语言编写的服务之间可以通过RPC进行通信,如Java服务调用Python服务。
  • 高性能计算:在需要高效、低延迟的系统中,RPC用于远程函数调用,如金融交易系统中的交易处理。

一些问题

什么是RPC框架,有哪些好处?

        可以理解为RPC框架是一种软件框架或者库,用于简化在不同计算机或者进程之间进行远程调用的过程。

        如果是一个大型的网站,内部子系统较多、接口非常多的情况下,RPC框架的好处就显示出来了:首先就是长链接,不必每次通信都要像http一样去3次握手什么的,减少了网络开销等。

1. 性能

  • HTTP:HTTP请求每次都需要建立连接(除非使用HTTP/1.1的持久连接),并且每次请求和响应都包含较多的头部信息。这些都会带来额外的开销,影响性能。
  • RPC:通常使用长连接,减少了连接建立的开销。RPC可以基于更高效的传输协议(如TCP或gRPC),从而降低延迟和提高传输效率。

2. 数据格式

  • HTTP:常使用文本格式(如JSON、XML)进行数据传输,解析这些格式需要额外的计算资源,尤其是在高频通信时。
  • RPC:可以使用二进制格式进行数据传输(如Protocol Buffers),这不仅节省带宽,还减少了序列化和反序列化的开销。

3. 透明性和易用性

  • HTTP:需要开发者手动构建请求和处理响应,这在复杂系统中会增加代码量和维护成本。
  • RPC:通过抽象远程调用过程,使得调用远程服务就像调用本地函数一样,隐藏了底层通信细节,提高了代码的可读性和维护性。

4. 功能和特性

  • HTTP:主要用于无状态的请求-响应模式,缺乏一些高级特性(如负载均衡、重试机制)。
  • RPC:许多RPC框架(如gRPC)内置了丰富的功能,包括负载均衡、重试、超时控制、流式传输等,这些功能对于构建可靠的微服务系统非常重要。

5. 协议和扩展性

  • HTTP:是一个通用的应用层协议,虽然可以用于微服务通信,但它的通用性也意味着它可能不够专门化,无法提供某些特定的优化。
  • RPC:专为服务间通信设计,可以提供更专门化的优化和扩展,适合高性能、低延迟的服务间通信。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/24742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Springboot使用redis分布式锁的方法

要想使用redis分布式锁很好地支撑我们的业务 需要确保&#xff1a; 1.加锁要保证原子性&#xff1b; 2.解锁要保证原子性。 示例代码&#xff1a; public Map<String, List<Catelog2Vo>> getCatelogJsonFromDbWithRedisLock() {//使用redis分布式锁&#xff…

Javascript全解(基础篇)

语法与数据类型 语法 var\let\const var 声明一个变量&#xff0c;可选初始化一个值。 let 声明一个块作用域的局部变量&#xff0c;可选初始化一个值。 const 声明一个块作用域的只读常量。 用 var 或 let 语句声明的变量&#xff0c;如果没有赋初始值&#xff0c;则其值为 …

人工智能系统越来越擅长欺骗我们?

人工智能系统越来越擅长欺骗我们&#xff1f; 一波人工智能系统以他们没有被明确训练过的方式“欺骗”人类&#xff0c;通过为他们的行为提供不真实的解释&#xff0c;或者向人类用户隐瞒真相并误导他们以达到战略目的。 发表在《模式》(Patterns)杂志上的一篇综述论文总结了之…

店匠科技亮相VivaTech,新零售解决方案引关注

在中法建交60周年之际,两国关系持续发展并共同推动双方在人工智能和全球治理领域达成重要合作。同时,浙江-法国高新产业创新合作对接会在巴黎顺利举行,进一步促进了中法两国在高新技术领域的交流与合作。 紧跟此次访问的步伐,众多中国科技创新企业齐聚巴黎,于5月22日至25日在法…

浅谈安全用电管理系统对重要用户的安全管理

1用电安全管理的重要性   随着社会经济的不断发展&#xff0c;电网建设力度的不断加大&#xff0c;供电的可靠性和供电质量日益提高&#xff0c;电网结构也在不断完善。但在电网具备供电的条件下&#xff0c;部分高危和重要电力用户未按规定实现双回路电源线路供电&#xff1…

代码随想录算法训练营第五十三天 | 309.最佳买卖股票时机含冷冻期、714.买卖股票的最佳时机含手续费

309.最佳买卖股票时机含冷冻期 视频讲解&#xff1a;动态规划来决定最佳时机&#xff0c;这次有冷冻期&#xff01;| LeetCode&#xff1a;309.买卖股票的最佳时机含冷冻期_哔哩哔哩_bilibili代码随想录 解题思路 1. dp[i][0] 第i天持有股票的状态 dp[i][1]第i天不持股的状…

Elasticsearch:ES|QL 查询 TypeScript 类型(二)

在我之前的文章 “Elasticsearch&#xff1a;ES|QL 查询 TypeScript 类型&#xff08;一&#xff09;”&#xff0c;我们讲述了如何在 Nodejs 里对 ES|QL 进行查询。在今天的文章中&#xff0c;我们来使用一个完整的例子来进行详细描述。更多有关如何使用 Nodejs 来访问 Elasti…

JavaScript中的 和 || 区别

在 JavaScript 中&#xff0c;&& 操作符被称为逻辑与操作符。当使用 && 操作符连接两个表达式时&#xff0c;它会首先计算左侧的表达式&#xff1a; 如果左侧的表达式为 false 或者可以转换为 false 的值&#xff08;如 null、undefined、0、“” 空字符串或 …

初入阿里云,上手走一波

初入阿里云&#xff0c;上手走一波 一阶&#xff1a;ECSMysqlDMS安装Mysql初始化MysqlMysql操作DMS管理Mysql 二阶&#xff1a;ECSOSS远程连接ECSOSS控制台其他图片服务 三阶&#xff1a;更多搭配操作 可以说个人在日常使用过程中&#xff0c;操作最多的阿里云产品就是阿里云服…

全身控制(Whole-Body Control,WBC)简化版

全身控制&#xff08;Whole-Body Control&#xff0c;WBC&#xff09;概述 WBC是一种集成了多种控制策略的方法&#xff0c;旨在同时控制人形机器人的多个自由度&#xff08;DOF&#xff09;&#xff0c;以实现复杂的运动和任务。WBC通常通过优化来解决&#xff0c;同时考虑到…

Python爬虫实战:从入门到精通

网络爬虫&#xff0c;又称为网络蜘蛛或爬虫&#xff0c;是一种自动浏览网页的程序&#xff0c;用于从互联网上收集信息。Python由于其简洁的语法和强大的库支持&#xff0c;成为开发网络爬虫的首选语言。 环境准备 Python安装 必要的库&#xff1a;requests, BeautifulSoup, Sc…

使用 LLaMA-Factory 实现对大模型函数调用功能

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学。 针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 合集&#x…

现代密码学-认证、消息认证码

什么是单向散列函数 单向散列函数&#xff08;one way hash function&#xff09;&#xff1a;一个输入&#xff1a;消息&#xff08;message&#xff09;,一个固定长度的输出(散列值&#xff0c;hash value),根据散列值检查消息完整性(integrity) 单向散列函数也称为消息摘要…

linux中创建sftp

前言&#xff1a;每次创建sftp的时候总是查一堆文档&#xff0c;不是有的步骤不对&#xff0c;就是缺失步骤&#xff0c;索性自己写一份以供后续方便使用。 一、添加用户组sftp --> groupadd sftp ●查看用户组是否创建成功 --> cat /etc/group 二、创建用户&#xf…

Docker大学生看了都会系列(七、Dokcerfile详解)

系列文章目录 第一章 Docker介绍 第二章 2.1 Mac通过Homebrew安装Docker 第二章 2.2 CentOS安装Docker 第三章 Docker常用命令 第四章 常用命令实战 第五章 Docker镜像详解 第六章 Docker容器数据卷 第七章 Dockerfile详解 第八章 Dokcerfile部署go项目 文章目录 一、Dockerfil…

图形化红队行动辅助平台Viper使用记录

图形化红队行动辅助平台Viper使用记录 简介 Viper(炫彩蛇)是一款图形化内网渗透工具,将内网渗透过程中常用的战术及技术进行模块化及武器化. Viper(炫彩蛇)集成杀软绕过,内网隧道,文件管理,命令行等基础功能. Viper(炫彩蛇)当前已集成70个模块,覆盖初始访问/持久化/权限提升/…

Python 中的字符串、列表、元组和字典数据类型的特点和使用场景

字符串&#xff08;str&#xff09;是一种不可变的序列类型&#xff0c;由字符组成。它的特点是&#xff1a; 可以使用单引号或双引号来定义字符串。字符串中的字符是按照索引进行访问的&#xff0c;索引从0开始。字符串可以进行切片操作&#xff0c;获取部分子串。字符串可以…

【数据结构】初识数据结构之复杂度与链表

【数据结构】初识数据结构之复杂度与链表 &#x1f525;个人主页&#xff1a;大白的编程日记 &#x1f525;专栏&#xff1a;C语言学习之路 文章目录 【数据结构】初识数据结构之复杂度与链表前言一.数据结构和算法1.1数据结构1.2算法1.3数据结构和算法的重要性 二.时间与空间…

【FPGA】arm数据总线和axi数据总线有什么异同点?

ARM数据总线和AXI数据总线在概念和应用上有一些异同点&#xff1a; 相同点 功能目的&#xff1a;两者都是用于处理器与外部设备或内存之间传输数据的通道。设计原则&#xff1a;它们都遵循一些设计原则&#xff0c;以确保数据传输的可靠性和效率。 异同点 架构级别&#xff…

Elasticsearch 认证模拟题 - 13

一、题目 集群中有索引 task3&#xff0c;用 oa、OA、Oa、oA 查询结构是 4 条&#xff0c;使用 dingding 的查询结果是 1 条。通过 reindex 索引 task3 为 task3_new&#xff0c;能够使 task3_new 满足以下查询条件。 使用 oa、OA、Oa、oA、0A、dingding 查询都能够返回 6 条…