HTTP&RPC

身为 Java Web 开发我发现很多人一些 Web 基础问题都答不上来。
上周我面试了一个三年经验的小伙子,他简历写着写着对操作系统、计算机网络、算法都比较熟悉。
我心里想,这个小伙子看起来胸有成竹好像有点东西,我就问:你挑个你最有自信的我先问问。
这是想找个他最有自信的看看他到底有多强。
一开始我问他 HTTP/1、HTTP/2 相关的他到是能答点东西出来。
就是 HTTP1.1什么特性,哪里哪里不好。
然后 HTTP2 什么特性,比 HTTP1.1 好在哪里哪里这样。
但是他的一些措辞让我感觉是把 HTTP 作为一个“运输通道”。
所以后来我问他:你怎么理解 HTTP 的,它的本质是什么,有什么用?
面试者愣一会儿,我接着问:就是说 HTTP 的作用,为什么客户端和服务端要用 HTTP 这个协议来通信。
他说是提供了一个通道来传输数据。
我说 HTTP 是一个协议。

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

为什么要有 RPC?

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

行那我再来问问你项目相关的吧。

后来关于项目细节、整体架构和一些场景的处理都问了,小伙子都答不好,最后我跟他说回家等通知吧。

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

当然我同事也经常问我问题,我也答不好,就共同进步,走向人生巅峰,迎娶那啥啥的。

HTTP 的本质

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

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

重点来了。

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

这是 TCP/IP 干的。

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

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

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

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

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

而交互就需要一种格式。

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

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

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

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

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

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

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

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

image.png

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

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

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

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

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

image.png

所以 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); // 这是远程调用,逻辑是用户小组的服务实现的。
    }

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

image.png

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

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

可以看到 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 是对等关系,不过相信大家看了之前的解析心里应该都有数了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,948评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,371评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,490评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,521评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,627评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,842评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,997评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,741评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,203评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,534评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,673评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,339评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,955评论 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,770评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,000评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,394评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,562评论 2 349

推荐阅读更多精彩内容