HTTP 的本质?HTTP 和 RPC 的区别?

待兔 等级 837 1 0

身为 Java Web 开发我发现很多人一些 Web 基础问题都答不上来。

上周我面试了一个三年经验的小伙子,一开始我问他 HTTP/1、HTTP/2相关的他到是能答点东西出来。

后来我问他:你怎么理解 HTTP 的,HTTP 的作用是什么?

他支支吾吾答不出来。

经过了一番引导交谈,他回答是用来客户端和服务端之间传输的。

我接着问那你知道什么是 HTTP 和 RPC 的关系吗?

为什么要有 RPC?

他眼睛盯着桌上的水,额了半天。

最后我跟他说回家等通知吧(当然还有很多都答不上来哈,多方位我都问了)。

面完试之后我回去问了同事相同的问题,我发现答的也不够好,有些地方有点混淆。

所以今儿我就整理一波来说说这类问题,相信看完文章之后你会有进一步的认识。

HTTP 的本质?HTTP 和 RPC 的区别?

HTTP 的本质

首先你要明确 HTTP 是一个协议,是一个超文本传输协议。

它基于 TCP/IP 来传输文本、图片、视频、音频等。

重点来了

HTTP 不提供数据包的传输功能,也就是数据包从浏览器到服务端再来回的传输和它没关系。

这是 TCP/IP 干的。

那 HTTP 有啥用?我们来分析一波。

我们上网要么就是获取一些信息来看,要么就是修改一些信息。

比如你用浏览器刷微博就是获取信息,发微博就是修改信息。

所以说浏览器需要告知服务器它需要什么,这次的请求是要获取哪些信息?发怎么样的微博。

这就涉及到浏览器和服务器之间的通信交互。

交互就需要一种格式

像你我之间的谈话就用中文,你要突然换成俄语我听不懂那不就 GG 了。

所以说 HTTP 它规定了一种格式,一种通信格式,大家都用这个格式来交谈。

这样不论你是什么服务器、什么浏览器都能顺利的交流,减少交互的成本

就像全世界如果都讲中文,那我们不就不需要学英文了,那不就较少交互的成本了。

不像现在我们还得学英文,不然就看不懂文档等等。

万一之后俄语又起来了,咱还得对接俄文,这交互成本是不是就上来了。

而网络世界还好,咱们现在的 Web 交互基本上就是 HTTP 了。

其实 HTTP 协议的格式很像我们信封,有个固定的格式。

HTTP 的本质?HTTP 和 RPC 的区别?

左上角写邮编,右上角贴邮票,然后地址姓名啥的依次来。

因为计算机是很死板的,不像我们人一样有一种立体扫描感,所以要规定先写头、再写尾。

你要是先写尾,再写头计算机就认不出来了。

所以 HTTP 就规定了请求先搞请求行、再搞请求报头、再搞请求体。

响应就状态行、响应报头、响应体。

HTTP 的本质?HTTP 和 RPC 的区别?

所以 HTTP 的本质是什么?

就是客户端和服务端约定好的一种通信格式

对 HTTP 想有多的认识可以看我之前的文章 从 1950 年开始说起,带你看 HTTP 的演进之路

HTTP 和 RPC 的关系

HTTP 和 RPC 其实是两个维度的东西, HTTP 指的是通信协议。

而 RPC 则是远程调用,其对应的是本地调用。

RPC 的通信可以用 HTTP 协议,也可以自定义协议,是不做约束的。

像之前的单体时代,我们的 service 调用就是自己实现的方法,是本地进程内的调用。

 public User getUserById(Long id) {
       return userDao.getUserById(id); // 这叫本地调用
    } 

现在都是微服务了,根据业务模块做了不同的拆分,像用户的服务不用我这个小组负责,我这小组只要写订单服务就行了。

但是我们服务需要用到用户的信息,于是我们需要调用用户小组的服务,于是代码变成了以下这种

 public User getUserById(Long id) {
       return userConsumer.getUserById(id); // 这是远程调用,逻辑是用户小组的服务实现的。
    } 

可能还有些小伙伴不太清楚,再来看个图。

HTTP 的本质?HTTP 和 RPC 的区别?

把之前的用户实现拆分出来弄了一个用户服务,订单相关的也拆成了订单服务,都单独部署。

这样订单相关的服务要获取用户的信息就需要远程调用了。

可以看到 RPC 就是通过网络进行远程调用,订单服务其实就是客户端,而用户服务是服务端。

这又涉及到交互了,所以也需要约定一个格式,至于要不要用 HTTP 这个格式,就是大家自己看着办

至此相信你对 HTTP 是啥也清楚了。

RPC 和 HTTP 的之间的关系也清楚了。

下次再也不怕被面试官问这个了。

那为什么要有 RPC?

可能你常听到什么什么之间是 RPC 调用的,那你有没有想过为什么要 RPC, 我们直接 WebClient HTTP 调用不行么?

其实 RPC 调用是因为服务的拆分,或者本身公司内部的多个服务之间的通信。

服务的拆分独立部署,那服务间的调用就必然需要网络通信,用 WebClient 调用当然可行,但是比较麻烦。

我们想即使服务被拆分了但是使用起来还是和之前本地调用一样方便

所以就出现了 RPC 框架,来屏蔽这些底层调用细节,使得我们编码上还是和之前本地调用相差不多。

并且 HTTP 协议比较的冗余,RPC 都是内部调用所以不需要太考虑通用性,只要公司内部保持格式统一即可。

所以可以做各种定制化的协议来使得通信更高效

比如规定 yes 代表 yes的练级攻略,你看是不是更高效了,少传输的 5 个字。

就像特殊行动的暗号,高效简洁!

所以公司内部服务的调用一般都用 RPC,而 HTTP 的优势在于通用,大家都认可这个协议。

所以三方平台提供的接口都是通过 HTTP 协议调用的

所以现在知道为什么我们调用第三方都是 HTTP ,公司内部用 RPC 了吧?

对了。

上面这段话看起来仿佛 HTTP 和 RPC 是对等关系,不过相信大家看了之前的解析心里应该都有数了。

最后

最近几次面试下来我发现挺多同学基础还是挺薄弱的。

地基要牢啊,八股文得背没错,但是这种基本概念性的东西还是有必要清晰的。

看起来好像对平时的编码没什么用,但是这可以认为是一个“世界观”。

这对于一些事物的判断和认知有很重要的意义。

你站的高才能看的远。

对了,理解了 HTTP 的本质相信你对 RESTful 风格也应该会有更深一层的理解。

HTTP 它是协议,不是运输通道。

下一篇我会剖析下 RESTful ,让你知其然知其所以然。

平日的面试题遇到难处,或者看某个知识点翻遍全网的资料还是感觉很模糊、不透彻,可以私聊我,给我留言。

遇到合适的我会整理写出一篇文章,注意这个前提我认为合适的。

那种工作遇到很细节的场景的还是别了,这种问你上司比较合适:)。


我是 yes,从一点点到亿点点,欢迎在看、转发、留言,我们下篇见。

HTTP 的本质?HTTP 和 RPC 的区别?

收藏
评论区

相关推荐

HTTP 的本质?HTTP 和 RPC 的区别?
身为 Java Web 开发我发现很多人一些 Web 基础问题都答不上来。 上周我面试了一个三年经验的小伙子,一开始我问他 HTTP/1、HTTP/2相关的他到是能答点东西出来。 后来我问他:你怎么理解 HTTP 的,HTTP 的作用是什么? 他支支吾吾答不出来。 经过了一番引导交谈,他回答是用来客户端和服务端之间传输的。 我接着问那你知道什么是
2014 春节发帖第 9 天:Go 语言的 RPC 介绍
标准库的 RPC -------- RPC 是远程调用的简称, 简单的说就是要调用本地函数一样调用服务器的函数. Go 语言的标准库已经提供了 RPC 框架和不同的 RPC 实现. 下面是一个服务器的例子: type Echo int func (t *Arith) Hi(args string, reply *string
gRPC学习以及实践
相信大家都听过RPC、HTTP、Socket等协议,他们均可用于业务中来进行数据通信,又根据各自协议的特点,应用场景也比较多样、复杂,那大家是否听过或者了解gRPC呢?用来做什么呢?我们就来了解一下gRPC以及其用途。 介绍 -- 用官方网站1一句话介绍介绍gRPC A high-performance, open source univers
gRPC应用C++
1.  gRPC简述 ---------- RPC,远程方法调用,就是像调用本地方法一样调用远程方法。 [gRPC](http://www.oschina.net/p/grpc-framework)是Google实现的一种RPC框架,基于HTTP/2标准设计,带来诸如双向流、流控、头部压缩、单 TCP 连接上的多复用请求等特。这些特性使得其在移动设备上表
Java使用Netty实现简单的RPC
造一个轮子,实现RPC调用 ============= > 在写了一个Netty实现通信的简单例子后,萌发了自己实现RPC调用的想法,于是就开始进行了Netty-Rpc的工作,实现了一个简单的RPC调用工程。 > 如果也有兴趣动手造轮子的同学,可以先看看之前写的 [使用Java实现Netty通信](https://www.oschina.net/acti
RPC、RMI、HTTP、REST的区别
**RPC、RMI、HTTP、REST的区别** ======================== **RPC:**远程服务调用(Remote Procedure Call),加上Protocol后可以称为远程过程调用协议,可以用不同的语言实现,可以借用HTTP协议或者其他协议来实现,一般都是通过基于TCP/IP的自定义协议实现。 HTTP协议和TCP/
RPC 定义 和 原理
一、RPC ----- ####   1. RPC是什么   RPC(Remote Procedure Call Protocol)——**远程过程调用协议**,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC跨越了*
RPC调用(架构)和HTTP调用(架构)的区别
我是接触到了Dubbo,才接触到RPC服务的。它处于的网络模型的传输层,而http处于应用层,RPC处于更底层所以效率更高! 本文简单地介绍一下两种形式的C/S架构,先说一下他们最本质的区别,就是RPC主要是基于TCP/IP协议的,而HTTP服务主要是基于HTTP协议的,我们都知道HTTP协议是在传输层协议TCP之上的,所以效率来看的话,RPC当然是要更胜
Dubbo 在 K8s 下的思考
作者 | 曹胜利  Apache Dubbo PMC > **导读**:Dubbo 作为高性能 Java RPC 框架的刻板印象早已深入人心,在 Cloud Native 的架构选型上,Spring Cloud 或许才是业界的优先选择。实际上,Dubbo 已经悄然地衍进为 Cloud Native 基础设施,不仅承袭过去 RPC 时代的荣耀,而且也完善了现
Filecoin RPC API官方文档【中文版】
JSON-RPC是一种标准的远程调用方式,在以太坊和比特币等区块链实现中都得到了广泛的应用。Filecoin Lotus也是使用JSON-RPC实现服务进程与客户端的通信,默认监听端口为1234,支持HTTP和Websocket。Filecoin RPC API中文文档由汇智网提供,访问地址:[http://cw.hubwiz.com/card/c/file
Kurento协议
Kurento媒体服务器可以被两种外部Kurento客户端控制,如Java或JavaScript。这些客户端使用Kuernto协议来和KMS通信。Kurento 协议是基于WebSocket协议,并使用了JSON-RPC V2.0 消息来提交请求和发送响应。 ### JSON-RPC 消息格式 Kurento协议使用JSON-RPC V2.0 编码它的消
RestFul 与 RPC
原文地址:https://blog.csdn.net/u014590757/article/details/80233901 RPC、REST API深入理解 一:RPC RPC 即远程过程调用(Remote Procedure Call Protocol,简称RPC),像调用本地服务(方法)一样调用服务器的服务(方法)。通常的实现有
Rpc基础 原理 框架
**一.** **RPC****的原理** **1.RPC****是什么** RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。RPC协议假定某些传输协议的存在,如TCP或UDP,为通信程序之间携带信息数据。在OSI网络通信模型中,RPC
Solon rpc 之 SocketD 协议
> Solon rpc 之 SocketD 协议系列 > > * [Solon rpc 之 SocketD 协议 - 概述](https://my.oschina.net/noear/blog/4888445) > * [Solon rpc 之 SocketD 协议 - 消息上报模式](https://my.oschina.net/noear/bl
Spring原生Rpc六种实现的正确打开方式
前言 == 在java生态圈谈到Rpc,很多人可能就会想到Dubbo、Motan、Grpc等框架。但是你知道吗?作为Java编程全家桶的Spring已经内置了多种RPC的实现方式,可以直接使用。存在即合理,有些场景下其实并不需要Dubbo,Grpc等重量级的RPC组件,那么Spring的轻量封装就可以派上用场了。下面就来探索下Spring中的RPC的实现方