中间件之RPC

 

一、RPC的定义

1、RPC(Romote Procedure Call):远程过程调用,允许一台计算机程序远程调用另外一台计算机的子程序,不用关心底层网络通信

2、应用:分布式网络通信

3、在Socket的基础上实现,比socket需要更多资源

4、可作为一种通信协议(Romote Procedure Call Protocol),远程过程调用协议,通过网络从远程计算机程序上请求服务

二、RPC的特点

1、透明性:调用其它机子的程序像用本地的一样

2、高性能:RPCserver服务器能并发处理多个Client请求

三、RPC的编程思想

1、仍然采用C/S编程模式,采用同步方式进行通信

2、允许本地程序Client调用存放于远程主机Service,和调用本地的没有区别

3、引入存根(stub)概念

存根:1)存在于服务器2)接受客户存根的请求3)和远程对象进行交互4)传送服务器相应到客户5)负责事物:解压客户端的输入远程方法的参数调用实际的远程对象的方法将结果打包返回给调用者

 

四、RPC的工作原理

1、发送方的地址空间中创建stub,接收方也创建一个

2、发送方和本地stub通信,本地stub在和接收方stub通信

3、将远程通信封装在stub中,发送方只和本地代理通信,接受方从本地stub获得所有请求

 

五、RPC的局限

1、客户端和服务器的计算机操作系统不一致会出现意想不到的错误

2、由于网络的复杂性,可能限制消息的尺寸,可能会丢失和重排消息

3、编程语言不同也会导致问题

4、由于是面向过程,所以近年来进展不大

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/438297.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Redis 持久化方式

Redis 提供了两种持久化方式:RDB (默认) 和 AOF。 RDB 内存快照,简而言之,就是在不同的时间点,将 redis 存储的数据生成快照并存储到磁盘等介质上 AOF 日志文件:AOF的全称叫append-only file&…

需求分析之UML用例图学习

用例图常用的三种关系浅析: (一)泛化(Inheritance) 通常理解的继承关系 (二)包含(include) 分解功能,一定包含的功能 (三)拓展(extend) 附加功能&#xff0c…

RSA公私钥加解密方式-工具类

直接上代码 ​ import java.io.ByteArrayOutputStream; import java.math.BigInteger; import java.security.*; import java.security.interfaces.RSAPrivateKey; import java.security.interfaces.RSAPublicKey; import java.security.spec.PKCS8EncodedKeySpec; import jav…

UML之用例图(use case)箭头方向

1、Association,无箭头,Actor连接UseCase即可; 2、DirectedAssocition,Actor连接UseCase,箭头由Actor指向UseCase(角色指向用例); 3、Generalization,继承,…

MD5加密方式-工具类

import org.slf4j.Logger; import org.slf4j.LoggerFactory;import java.security.MessageDigest;/*** Md5加密方法* * author */ public class Md5Utils {private static final Logger log LoggerFactory.getLogger(Md5Utils.class);private static byte[] md5(String s){Mes…

UML-记忆技巧

箭头方向 UML箭头方向:从子类指向父类,读作继承自定义子类时需要通过extend关键字指定父类子类一定时知道父类定义的,但父类并不知道子类的定义 只有知道对方信息时才能指向对方 image.png 实现-继承|虚线-实现 空心三角箭头&#xff1…

动态定时任务数据库获取方式

Spring 中,创建定时任务除了使用Scheduled 注解外,还可以使用 SchedulingConfigurer。 Schedule 注解有一个缺点,其定时的时间不能动态的改变,而基于 SchedulingConfigurer 接口的方式可以做到。SchedulingConfigurer 接口可以实…

国密算法SM2,SM3,SM4-java实现

SM2是国家密码管理局于2010年12月17日发布的椭圆曲线公钥密码算法,基于ECC。其签名速度与秘钥生成速度都快于RSA,非对称加密,该算法已公开 SM3是中华人民共和国政府采用的一种密码散列函数标准,由国家密码管理局于2010年12月17日…

数据库事务隔离级别-- 脏读、幻读、不可重复读(清晰解释)

一、数据库事务隔离级别 数据库事务的隔离级别有4个,由低到高依次为Read uncommitted 、Read committed 、Repeatable read 、Serializable ,这四个级别可以逐个解决脏读 、不可重复读 、幻读 这几类问题。 √: 可能出现 : 不会出现 脏读不可重复读幻…

国密算法SM2-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> 工具类 import java.math.BigInteger;public class Util {/*** 整形转换成网络…

原子性和一致性的区别是什么?

注&#xff1a; 重度参考了&#xff1a;https://www.zhihu.com/question/30272728/answer/72476703&#xff08;讲的非常好&#xff0c;逻辑清晰&#xff09; 轻度参考了&#xff1a;https://www.cnblogs.com/fjdingsd/p/5273008.html&#xff08;概念也比较清晰&#xff0c;…

国密算法SM3-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> SM3Utils import org.bouncycastle.crypto.digests.SM3Digest; import org.b…

什么是事务、事务特性、事务隔离级别、spring事务传播特性

1.什么是事务&#xff1a; 事务是指程序中的一个操作序列。其特点是&#xff1a;该序列的所有操作要么全部成功完成&#xff0c;要么只要有一个操作失败&#xff0c;则该序列所有操作都将被撤销。这也是事务的原子性&#xff08;要么成功&#xff0c;要么失败&#xff09;。 …

国密算法SM4-java实现

Maven依赖 <dependency><groupId>org.bouncycastle</groupId><artifactId>bcprov-jdk15on</artifactId><version>1.56</version> </dependency> SM4 import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputS…

软件工程 – 开发模型

软件工程 – 开发模型 为了指导软件开发&#xff0c;可以用不同的方式将软件生命周期中的所有开发活动组织组织起来从而形成不同的开发模型。 瀑布模式 瀑布模型严格遵守软件生命周期各阶段的固定顺序:计划、分析、设计、编程、测试和维护&#xff0c;上一阶段完成才能进入到…

Microsoft.CSharp.dll程序集的作用

《C#与.NET 4高级程序设计:第5版》第18章动态类型和动态语言运行时&#xff0c;本章&#xff0c;我们将学习dynamic关键字的方方面面&#xff0c;理解如何使用DLR &#xff08;Dynamic Language Runtime&#xff0c;动态语言运行时&#xff09;将松散的类型映射到正确的内存对象…

排序算法之选择排序

动图演示 使用场景:适用于大多数排序,数据量大效率明显优于冒泡 java代码实现 import java.util.Arrays;/*** 选择排序*/ public class SelectSort {private static int[] selectSort(int[] arr) {if (arrnull||arr.length<2){return arr;}//控制循环次数,最后一个元素不用…

VS的包含目录、库目录、引用目录、可执行目录解释

来源&#xff1a;包含目录、库目录、附加包含目录、附加库目录、附加依赖项之详解 学习备份 VS项目中的包含目录、库目录、附加包含目录、附加库目录、附加依赖项均在”项目->属性->配置属性”下进行配置&#xff0c;具体说明如下&#xff1a; VC目录&#xff1a; 包含目…

排序算法之插入排序

动图演示 使用场景:数据有序程度越高,效率越高 java代码实现 import java.util.Arrays;/*** 插入排序*/ public class InsertSort {private static int[] insertSort(int[] arr) {if (arrnull||arr.length<2){return arr;}// 从下标为1的元素开始选择合适的位置插入&…

第一节:复习委托,并且通过委托的异步调用开启一个新线程和异步回调、异步等待。

一. 再谈委托 1. 委托是一个关键字为delegate的自定义类型&#xff0c;通过委托可以把方法以参数的形式传递给另外一个方法&#xff0c;实现插件式的开发模式&#xff1b; 同时调用委托的时候&#xff0c;委托所包含的所有方法都会被实现。 2. 委托的发展历史&#xff1a;new…