RPC协议了解

RPC协议了解1.RPC概述RPC(RemoteProcedureCallProtocol)远程过程调用协议。通俗的描述是:客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个过程或函数,就像调用本地应用程序中的一样。正确的描述是:一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。2.RPC特点:2.1)RPC是协议:协议意味着规范。目前典型的RPC实现包括Dubbo、Thrift、Herrty等。但这些实现往往都会附加其他重要功能,例如Dubbo还包括服务管理、访问权限

大家好,又见面了,我是你们的朋友全栈君。

1.RPC概述
RPC(Remote Procedure Call Protocol)远程过程调用协议。
通俗的描述是:客户端在不知道调用细节的情况下,调用存在于远程计算机上的某个过程或函数,就像调用本地应用程序中的一
样。
正确的描述是:一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。

2.RPC特点:
2.1)RPC是协议:协议意味着规范。目前典型的RPC实现包括Dubbo、Thrift、Herrty等。但这些实现往往都会附加其他重要功能
,例如Dubbo还包括服务管理、访问权限管理等功能。
2.2)网络协议和网络IO模型对其透明:既然RPC的客户端认为自己是在调用本地对象。那么传输层使用的是TCP/
UDP还是http协议,又或者是一些其他的网络协议它就不需要关心了。既然网络协议对其透明,那么调用过程中,使用的是哪一种网络IO模型调用者也不需要关心。
2.3)信息格式对其透明:远程调用过程中,需要传递一些参数,并且会返回一个调用结果。至于这些参数会以某种信息格式传递
给网络上的另一台计算机,这个信息格式是怎样构成的,调用方是不需要关心的。
2.4)跨语言能力:对于调用方来说,不知道也无需知道远程的程序使用的是什么语言运行的,无论服务器方使用的是什么语言,
本次调用都应该成功,并且返回值也应该按照调用方程序语言所能理解的形式描述。

3.RPC原理
3.1)实现RPC的程序包括5个部分:User、User-stub、RPCRuntime、Server-stub、Server。
3.2)user:就是发起RPC调用的client,当user想发起一个远程调用时,它实际是通过本地调用user-stub。user-stub负责将
调用的接口、方法和参数通过约定的协议规范进行编码并通过本地的RPCRuntime实例传输到远程的实例。远程RPCRuntime实例收到请求后交给server-stub进行解码后发起本地端调用,调用结果再返回给user端。
3.3)stub:为屏蔽客户调用远程主机上的对象,必须提供某种方式来模拟本地对象,这种本地对象称为存根(stub),存根负责
接收本地方法调用,并将它们委派给各自具体实现对象。

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/144241.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月19日 下午11:00
下一篇 2022年5月19日 下午11:00


相关推荐

  • java获取环境变量路径_Java读取系统环境变量的方法

    java获取环境变量路径_Java读取系统环境变量的方法Java 读取系统环境变量的方法时间 2017 08 30 来源 华清远见 JAVA 学院本文华清 Java 学院小编要和大家分享的是 Java 读取系统环境变量的方法 主要涉及到 java 读取系统环境变量方面的内容 对于 Java 开发感兴趣的同学可以参考一下 有时候在编写 Java 应用程序时 需要向文件系统写入数据文件 日志文件 这时就需要判断操作系统类型 当前用户的主目录等 从而规范文件写入 使应用程序能

    2026年3月20日
    2
  • kong网关架构_kong网关性能

    kong网关架构_kong网关性能Kong是一个使用了lua-nginx-module运行在Nginx之上的Lua应用。Kong是一个成熟的API网关解决方案。API网关,即APIGateway,是大型分布式系统中,为了保护内部服务而设计的一道屏障,可以提供高性能、高可用的API托管服务,从而帮助服务的开发者便捷地对外提供服务,而不用考虑安全控制、流量控制、审计日志等问题,统一在网关层将安全认证,流量控制,审计日志,黑白名单…

    2025年10月24日
    5
  • 阿里云Redis开发规范

    阿里云Redis开发规范

    2021年7月4日
    69
  • 腾讯云官宣赞助OpenClaw!2026最火AI Agent框架快速上手教程

    腾讯云官宣赞助OpenClaw!2026最火AI Agent框架快速上手教程

    2026年3月16日
    2
  • 中介模式和学习日记Effective C++

    中介模式和学习日记Effective C++

    2022年1月8日
    42
  • 字节和字符区别

    字节和字符区别字节字节 说白了就是 byte 二进制数据 通常在读取图片 声音 可执行文件需要用字节数组来保存文件 在下载文件也是用 byte 数组来做临时的缓冲器接收文件内容 字符机器只知道字节 而字符却是语义上的单位 它是有编码的 一个字符可能编码成 1 个 2 个甚至 3 个 4 个字节 这跟字符集编码有关系 英文字母和数字是单字节 但汉字这些自然语言中的字符是多字节的 一个字节只能表示 255 个字符 不可能用于全球

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号