进阶SpringBoot之分布式系统与 RPC 原理

分布式系统是若干独立计算机的集合,这些计算机对于用户来说就像单个相关系统

分布式系统是由一组通过网络进行通信,为了完成共同的任务而协调工作的计算机节点组成的系统

其目的是利用更多的机器,处理更多的数据

RPC(Remote Procedure Call)是指远程过程调用,是一种进程间通信方式,他是一种技术的思想,而不是规范

比如有两台服务器 A、B

一个应用部署在 A 服务器上,想要调用 B 服务器上应用提供的函数或方法

由于不在一个内存空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据

RPC 的作用就是像调用本地函数一样去调远程函数

1.首先,客户端调用

2.网络传输对象需要序列化,发送信息到服务端

3.服务端开始反序列化,调用本地服务

4.服务处理完后,将结果返回出去

5.最后返回到本地的一个调用结果

RPC 两个核心模块:通讯、序列化

通讯:传输

序列化:数据传输需要转换

相关推荐
neo_Ggx23几秒前
Linux 日志检索速查:按时间、接口、Trace ID 查询完整请求链路
java·linux·服务器
ch.ju1 分钟前
Java程序设计(第3版)第四章——什么是对象
java·开发语言
2301_7926748614 分钟前
java学习(day34)
java·开发语言·学习
拾光Ծ17 分钟前
【Linux系统】线程(上)
java·linux·运维·jvm·线程·c/c++
AI人工智能+电脑小能手18 分钟前
【大白话说Java面试题 第54题】【JVM篇】第14题:什么是可达性分析算法?
java·jvm·算法·面试
接着奏乐接着舞19 分钟前
java jvm知识点
java·开发语言·jvm
AI人工智能+电脑小能手21 分钟前
【大白话说Java面试题 第55题】【JVM篇】第15题:JVM有哪些垃圾收集算法?
java·jvm·算法·面试
摇滚侠23 分钟前
Java 基础面试题 真正的 offer 偏方 Java 基础 Java 高级
java·开发语言
蚰蜒螟27 分钟前
深入剖析 OpenJDK 17 解释器中的安全点(Safepoint)进入与退出机制
java·开发语言·安全
Generalzy31 分钟前
为什么 Go 的注释,能控制编译器?
java·python·golang