| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> 分布式之RPC -> 正文阅读 |
|
[网络协议]分布式之RPC |
RPC基础何为RPC?rpc,即为远程过程调用。 为什么要RPC? 因为,两个不同的服务器上的服务提供的方法不在一个内存空间,所以,需要通过网络编程才能传递方法调用所需要的参数。并且,方法调用的结果也需要通过网络编程来接收。但是如果手动网络编程实现这个调用过程的话工作量很大,因此需要考虑底层传输方式、序列化方式。 rpc能帮助我们做什么呢? 通过RPC可以帮助我们调用远程计算机上某个服务的方法,就像调用本地方法一样简单。并且不需要了解底层网络编程的具体细节。 RPC的原理是什么呢?RPC的核心功能分为6个部分实现的: 1.客户端:调用远程方法的一端 2.客户端stub(桩):这其实就是一个代理类。代理类就是调用方法、类、方法参数等信息传递到服务端。 3.网络传输:网络传输就是你要把你调用的方法的信息比如说参数传输到服务端,然后服务端执行完之后再把返回结果通过网络传输给你传输回来。 4.服务端的stub:这个桩不是代理类。服务端stub实际指的是接收到客户端执行方法请求后,去指定对应方法然后返回结果给客户端的类。 5.服务端:提供远程方法的一端。 1.服务消费端以本地调用的方式调用远程服务 2.客户端stub接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体(序列化):RpcRequest; 3.客户端stub找到远程服务地址,并将消息发送到服务提供端; 4.服务端stub将受到的消息反序列化为java对象:RpcRequest; 5.服务端stub根据RpcRequest中的类、方法、方法参数等信息调用本地的方法; 6.服务端stub得到方法执行结果并将组装成能够进行网络传输的消息的题 RpcResponse(序列化)发送至消费方; 7.客户端stub接收到消息将消息反序列化为java对象:RpcResponse,这样得到最终结果。over!; |
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/26 1:51:12- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |