RPC,即 Remote Procedure Call(远程过程调用),调用远程计算机上的服务,就像调用本地服务一
样。 RPC 可以很好的解耦系统,如 WebService 就是一种基于 Http 协议的 RPC。这个 RPC 整体框架
如下:
8.1.3.2. 关键技术
1. 服务发布与订阅:服务端使用 Zookeeper 注册服务地址,客户端从 Zookeeper 获取可用的服务
地址。
2. 通信:使用 Netty 作为通信框架。
3. Spring:使用 Spring 配置服务,加载 Bean,扫描注解。
4. 动态代理:客户端使用代理模式透明化服务调用。
5. 消息编解码:使用 Protostuff 序列化和反序列化消息。
8.1.3.3. 核心流程
1. 服务消费方(client)调用以本地调用方式调用服务;
2. client stub 接收到调用后负责将方法、参数等组装成能够进行网络传输的消息体;
3. client stub 找到服务地址,并将消息发送到服务端;
4. server stub 收到消息后进行解码;
5. server stub 根据解码结果调用本地的服务;
6. 本地服务执行并将结果返回给 server stub;
7. server stub 将返回结果打包成消息并发送至消费方;
8. client stub 接收到消息,并进行解码;
9. 服务消费方得到最终结果。
RPC 的目标就是要 2~8 这些步骤都封装起来,让用户对这些细节透明。 JAVA 一般使用动态代
理方式实现远程调用。
8.1.3.1. 消息编解码
息数据结构(接口名称+方法名+参数类型和参数值+超时时间+ requestID)
客户端的请求消息结构一般需要包括以下内容:
1. 接口名称: 在我们的例子里接口名是“HelloWorldService”,如果不传,服务端就不知道调用哪
个接口了;
2. 方法名:一个接口内可能有很多方法,如果不传方法名服务端也就不知道调用哪个方法;
3. 参数类型和参数值:参数类型有很多,比如有 bool、 int、 long、 double、 string、 map、 list,
甚至如 struct(class);以及相应的参数值;
4. 超时时间:
5. requestID,标识唯一请求 id,在下面一节会详细描述 requestID 的用处。
6. 服务端返回的消息 : 一般包括以下内容。返回值+状态 code+requestID

序列化
   目前互联网公司广泛使用 Protobuf、 Thrift、 Avro 等成熟的序列化解决方案来搭建 RPC 框架,这
些都是久经考验的解决方案。

rpc核心实现和原理相关推荐

  1. RPC框架:从原理到选型,一文带你搞懂RPC

    大家好,我是华仔,RPC系列的文章是我去年写的,当时写的比较散,现在重新进行整理.对于想学习RPC框架的同学,通过这篇文章,让你知其然并知其所以然,便于以后技术选型,下面是文章内容目录: RPC 什么 ...

  2. 计算机操作系统的新技术新知识,计算机操作系统教程:核心与设计原理

    计算机操作系统教程:核心与设计原理 语音 编辑 锁定 讨论 上传视频 <计算机操作系统教程--核心与设计原理>是2007年清华大学出版社出版的图书,作者是范策.许宪成.黄红桃. 书     ...

  3. 转 Spring源码剖析——核心IOC容器原理

    Spring源码剖析--核心IOC容器原理 2016年08月05日 15:06:16 阅读数:8312 标签: spring 源码 ioc 编程 bean 更多 个人分类: Java https:// ...

  4. 计算机系统设计原理pdf百度云,计算机操作系统教程--核心与设计原理习题1答案.pdf...

    计算机操作系统教程--核心与设计原理习题1答案.pdf (4页) 本资源提供全文预览,点击全文预览即可全文预览,如果喜欢文档就下载吧,查找使用更方便哦! 9.9 积分 习题 1 1.1 什么是操作系统 ...

  5. 区块链笔记 - 《区块链技术核心概念与原理讲解》

    说明:笔记内容来源于慕课网<区块链技术核心概念与原理讲解>视频课程.如有侵权,请联系删除. 目录 1.区块链前世今生 2.区块链前景 3.比特币是什么 4.比特币原理 4.1 账本如何验证 ...

  6. 区块链技术入门——核心概念与原理

    区块链的前世今生 密码朋克(Cypherpunk):是一个邮件组,里面有许多大牛. 比特币的底层技术: 点对点网络 时间戳 加密技术 工作量证明 可以应用到其他领域. 将这些技术提炼出来,就提出了区块 ...

  7. RPC框架的实现原理,及RPC架构组件详解

    RPC的由来 随着互联网的发展,网站应用的规模不断扩大,常规的垂直应用架构已无法应对,分布式服务架构以及流动计算架构势在必行,亟需一个治理系统确保架构有条不紊的演进. 单一应用架构 当网站流量很小时, ...

  8. dubbo 自定义路由_高性能可扩展分布式RPC框架Dubbo内核原理揭秘

    一.前言 整体来说,一个公司业务系统的演进流程基本都是从单体应用到多体应用.在单体应用时,不同业务模块相互调用直接在本地 JVM 进程内就可以完成;而变为多个应用时,相互之间进行通信的方式就不能简单的 ...

  9. 【Spark Core】【RDD】【01】核心属性 执行原理

    理解RDD 刚从地里挖出来的土豆食材.清洗过后的干净土豆.生薯片.烤熟的薯片,流水线上这些食材的不同形态,就像是 Spark 中 RDD 对于不同数据集合的抽象. RDD 具有 4 大属性,分别是 p ...

最新文章

  1. 2.2.3 C语言中的整数类型及类型转换(为什么强制类型转换值发生改变?带你从机器码的角度分析)
  2. 文件系统、mkdir、touch、nano、cp笔记
  3. Visual Studio 编译优化选项:Debug与Release、禁止优化与O1、O2、Ox优化
  4. 不看绝对血亏!java字符串转json
  5. 从零开始用python处理excel数据_Python对Excel的操作
  6. [转]Entity Framework 4.1 正式版发布
  7. 基于JAVA+SpringMVC+MYSQL的在线音乐网站
  8. SequoiaDB版本升级及导入导出工具说明
  9. pycharm中不能安装bs4的解决方案
  10. 谷歌技术quot;三宝quot;之MapReduce
  11. java t输出_java --输入输出
  12. Python实现LBP算法
  13. Qt for WebAssembly 环境配置 - 知其然并知其所以然
  14. linux 怎么批量删除文件,linux下批量删除文件
  15. 中国石油大学《物理化学》第一阶段在线作业
  16. java常见的异种类_JCA - 自然 - BlogJava
  17. σ-代数、可测集、测度、可测空间、概率空间、随机变量、概率分布函数
  18. ERROR: 报错分析 phase.raise_objection(this)不能是phase.raise_objection(phase)
  19. 小麦苗的微信公众号开通啦,欢迎大家扫码关注
  20. 磁条卡,IC卡,ID卡,信用卡芯片卡,信用卡磁条卡 等等的区别

热门文章

  1. HDU4532(组合DP)
  2. hdu3007(最小覆盖圆问题)
  3. Java笔记--实时更新
  4. C++中Struct和Class的区别
  5. Win32多线程编程(2) — 线程控制
  6. pycharm debug 断点调试
  7. HTTP的前世今生(HTTP1.1,HTTPS,SPDY,HTTP2.0,QUIC,HTTP3.0)
  8. 130 道 K8s + Docker + DevOps 大厂面试题及知识点详解
  9. Redis最佳实践指南
  10. 好文推荐 | 缓存与数据库一致性问题深度剖析 (修订)