Java面试——RPC协议

涉及到分布式方面知识的话,RPC协议是逃不开的,所以在此记录一下RPC协议。

什么是RPC协议

RPC协议(Remote Procedure Call)远程过程调用,简单的来说:RPC协议是一种通过网络从远程计算机程序获取服务的协议

通俗理解:A计算机提供一个服务,B计算机可以像使用本地服务一样去调用(或使用)A计算机的服务。

具体来说RPC协议可以分成4个角色Client、Client stub、Server、Server Stub。

Client是调用方、Server是服务的提供方

Client调用Server中的服务。

Client Stub表示客户端存根,专门用来存储服务端服务的地方

Server Stub表示服务端存根,专门用来接收客户端发送过来的消息,然后解析消息内容(反序列化)。

RPC协议与HTTP协议的区别?

功能特性上

HTTP:是属于应用层的超文本传输协议,是万维网数据通信的基础,主要在网页端和服务端的数据传输

RPC:是远程过程调用协议,他的定位是实现不同计算机应用的数据通信,屏蔽通信层的复杂性。

原理实现上

HTTP:是一个已经实现并成熟的应用层协议,其有完善的报文格式(即请求行、请求头、请求体)

RPC:只是一种协议规范,他没有具体的实现,只要按照RPC规范实现,都可以。

最后这俩其实都是应用层协议,并且基本上都是基于TCP协议(HTTP3.0不是TCP),同时RPC是一种标准协议,所以实现方式比较多样化,有RPC也可以用HTTP来实现(例如:gRPC、OpenFegin)。

相关推荐
Brookty14 小时前
【JavaEE】线程安全-内存可见性、指令全排序
java·开发语言·后端·java-ee·线程安全·内存可见性·指令重排序
青鱼入云14 小时前
【面试场景题】支付&金融系统与普通业务系统的一些技术和架构上的区别
面试·金融·架构
掘金安东尼14 小时前
黑客劫持:周下载量超20+亿的NPM包被攻击
前端·javascript·面试
tellmewhoisi14 小时前
前置配置1:nacos 基本配置(注册与发现)
java
会开花的二叉树15 小时前
继承与组合:C++面向对象的核心
java·开发语言·c++
长河16 小时前
Java开发者LLM实战——LangChain4j最新版教学知识库实战
java·开发语言
Cyan_RA917 小时前
SpringMVC @RequestMapping的使用演示和细节 详解
java·开发语言·后端·spring·mvc·ssm·springmvc
喵手19 小时前
玩转Java网络编程:基于Socket的服务器和客户端开发!
java·服务器·网络
在未来等你19 小时前
Elasticsearch面试精讲 Day 17:查询性能调优实践
大数据·分布式·elasticsearch·搜索引擎·面试
再见晴天*_*20 小时前
SpringBoot 中单独一个类中运行main方法报错:找不到或无法加载主类
java·开发语言·intellij idea