RPC概述

RPC是什么

RPC(Remote Procedure Call)远程过程调用协议,一种通过网络从远程计算机上请求服务,而不需要了解底层网络技术的协议。RPC它假定某些协议的存在,例如TPC/UDP等,为通信程序之间携带信息数据。在OSI网络七层模型中,RPC跨越了传输层和应用层,RPC使得开发,包括网络分布式多程序在内的应用程序更加容易。

过程是什么?

过程就是业务处理、计算任务,更直白的说,就是程序,就是想调用本地方法一样调用远程的过程

和本地调用有什么区别



远程调用,就好像异地恋一样,隔着千山万水



本地调用,就是女生就在你身边,近水楼台先得月

远程调用之间需要通过网络,所以响应要慢几个数量级,也不那么可靠

RPC模式

RPC采用客户端/服务端的模式,通过request-response消息模式实现

RPC的三个过程

1:通讯协议

比如:你需要找人在国外干活,那么你可以直接飞过去或者打电话或者通过互联网的形式,去找人,这个找人的过程就是通讯协议

2:寻址

既然要找人干活,肯定要知道地址在哪,飞过去需要找到详细地址,打电话需要知道电话号码,互联网需要知道IP是多少

3:数据序列化

就是说,语言需要互通,才能够让别人干活,之间需要一个大家都懂的语言去交流

为什么要使用RPC

1:服务化/微服务

2:分布式系统架构

3:服务可重用

4:系统间交互调用

RPC和其他协议的区别

RMI远程方法调用是RPC的一种具体实现,webservice、restfull都是RPC,只是消息的组织形式、消息协议不同

RPC使用场景

和MQ做对比:

MQ有一个中间节点queue,可以存储消息

RPC的特性:

同步调用,对于需要等待返回结果的场景,可以使用RPC

消息MQ的特性:

异步单向的消息,不需要等待消息处理完成

如果需要同步得到结果的场景,RPC比较适合,如果希望使用简单,RPC也适合,RPC操作基于接口,操作简单,使用的方式模拟本地方法的调用,异步的方式编程比较复杂

RPC的流程



1:客户端处理过程中调用client sub,就像调用本地方法一样,传入参数

2:client sub将参数编组为消息,然后通过系统调用向服务端发送消息

3:客户端本地的操作系统将消息从客户端发送到服务端

4:服务端将接收到的数据包传递给server sub

5:server sub将接收到的数据解组为参数

6:server sub再调用服务端的过程,过程执行的结果以反方向的相同步骤响应给客户端

sub(存根) :分布式计算中的存根是一段代码,它转换在远程过程调用(RPC)期间client和server之间传递的参数

需要处理的问题:

1:client sub、server sub的开发

2:参数的编组和解组

3:消息如何发送

4:过程结果如何表示、异常情况如何处理

5:如何实现安全的访问控制

RPC核心概念术语

1:client, 客户端

2:server,服务端

3:calls,请求

4:replier,响应

5:services,一个网络服务由一个或者多个远程程序集构成

6:programs,一个远程程序实现一个或多个远程过程

7:procedures,过程、过程的参数、结果在程序协议说明书中定义说明

8:version,为兼容程序协议变更,一个服务端可能支持多个版本的远程程序

RPC协议

RPC调用过程中需要将消息进行编组然后发送,接收方需要解组消息为参数,过程处理结果也需要经过编组、解组;消息由哪些部分构成以及消息的表示形式就构成了消息协议。

RPC协议规定请求消息、响应消息的格式,在TCP之上我们可以选用或者自定义消息协议来实现RPC的交互

RPC框架

封装好了参数编组、消息解组、底层网络通信的RPC程序开发框架,可以直接在此基础上编写,只关注过程代码

java领域中常用的RPC框架有:

传统的webservice框架:apache CXF、apache Axis2

新兴的微服务框架:Dubbo、springcloud、apache Thrift、ICE、GRPC等

服务暴露

远程提供者需要以某种形式提供服务调用相关的信息,包括但不限于服务接口定义、数据结构或者中间态的服务定义文件,web service的WSDL文件;服务调用者需要通过一定的途径获取远程服务调用相关的信息

远程代理对象

服务调用者使用的服务实际上是远程服务的本地代理,说白了就是通过动态代理实现

java中至少提供了两种动态代码的生成,一种是jdk动态代理,一种是字节码生成:

动态代理比字节码生成使用起来更加方便,但是性能上没有字节码生成好,字节码生成在代码可读性上要差一些

通信

RPC框架的通信与具体的协议无关,RPC可基于HTTP或者TCP协议

序列化

传输方式和序列化会直接影响RPC的性能

RPC理论介绍的更多相关文章

  1. 实例学习SSIS(五)--理论介绍SSIS

    原文:实例学习SSIS(五)--理论介绍SSIS 导读: 实例学习SSIS(一)--制作一个简单的ETL包 实例学习SSIS(二)--使用迭代 实例学习SSIS(三)--使用包配置 实例学习SSIS( ...

  2. 【转】RPC简单介绍

    RPC简单介绍 RPC 1. RPC是什么 RPC(Remote Procedure Call Protocol)——远程过程调用协议,它是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络 ...

  3. 远程服务调用RPC框架介绍,微服务架构介绍和RPC框架对比,dubbo、SpringClound对比

    远程服务调用RPC框架介绍,微服务架构介绍和RPC框架对比,dubbo.SpringClound对比 远程服务调用RPC框架介绍,RPC简单的来说就是像调用本地服务一样调用远程服务. 分布式RPC需要 ...

  4. RPC理论以及Dubbo的使用介绍

    RPC 的主要功能目标是让构建分布式应用更容易,在提供强大的远程调用能力时不损失本地调用的语义简洁性. 为实现该目标,RPC 框架需提供一种透明调用机制让使用者不必显式的区分本地调用和远程调用. RP ...

  5. [转]新兵训练营系列课程——平台RPC框架介绍

    原文:http://weibo.com/p/1001643875439147097368 课程大纲 1.RPC简介 1.1 什么是RPC 1.2 RPC与其他远程调用方式比较 2.Motan RPC框 ...

  6. Hadoop2源码分析-YARN RPC 示例介绍

    1.概述 之前在<Hadoop2源码分析-RPC探索实战>一文当中介绍了Hadoop的RPC机制,今天给大家分享关于YARN的RPC的机制.下面是今天的分享目录: YARN的RPC介绍 Y ...

  7. Thrift RPC框架介绍

    u 简介 Thrift是一种开源的跨语言的RPC服务框架.Thrift最初由facebook公司开发的,在2007年facebook将其提交apache基金会开源了.对于当时的facebook来说创造 ...

  8. (转)shiro权限框架详解01-权限理论介绍

    http://blog.csdn.net/facekbook/article/details/54890365 权限管理 本文介绍权限管理的理论和权限管理的一些名词. 介绍权限管理 理解身份认证和授权 ...

  9. Hadoop的RPC框架介绍

    为什么会引入RPC: RPC采用客户机/服务器模式.请求程序就是一个客户机,而服务提供程序就是一个服务器.当我们讨论HDFS的,通信可能发生在: Client-NameNode之间,其中NameNod ...

随机推荐

  1. HTTP/1.1 有点慢,我想优化下!

    问你一句:「你知道 HTTP/1.1 该如何优化吗?」 我想你第一时间想到的是,使用 KeepAlive 将 HTTP/1.1 从短连接改成长链接. 这个确实是一个优化的手段,它是从底层的传输层这一方 ...

  2. 用友U8+V12.0安装教程(有需要软件和服务的可以联系我)

    有需要用友U8+V12.0软件和服务的可以联系我 QQ:751824677  1.退出所有杀毒软件 2.先装服务器SQL2008 3.服务器(会计): 经典应用模式--全产品 (解压A盘-执行-Aut ...

  3. eclipse快速定位当前类所在位置

    如何快速的找到一个类并且定位它所在的位置呢?这里以搜索Menu类为例说明. 可以通过CTRL + SHIFT +R的组合键,输入Menu 双击Menu.java即可跳转到对应的类上,但此时还不知道此类 ...

  4. Springboot项目架构设计

    导航 前言 流水线 架构的艺术 项目架构 理解阿里应用分层架构 superblog项目架构 结语 参考 本节是<Spring Boot 实战纪实>的第7篇,感谢您的阅读,预计阅读时长3mi ...

  5. 一个操作 cookie 的原生方法 cookieStore

    我们平时对 cookie 的增删改查等操作,都是在操作 document.cookie,这里我们介绍一个新方法cookieStore. 1. 平时如何操作 cookie document.cookie ...

  6. HDU-6862 Hexagon (2020HDU 多校 D8 H)

    1008 题意:半径为n的六边形(由半径为1的小六边形组成),从某一个小六边形出发有六个方向,找到一条转向次数最多的路径(用方向表示)遍历所有的六边形(一个六边形只访问一次). 题解:先画出n=3/4 ...

  7. D8016 “/ZI”和“/Gy-”命令行选项不兼容

    老版本vs项目升级到vs2017后遇到编译报错: /ZI选项在: /Gy- 选项在: 修改'/ZI'选项为'无' 或者 '/Gy-' 修改为'/Gy'

  8. 图解 | 原来这就是 class

    我是一个 .java 文件,名叫 FlashObject.java,叫我小渣就行. public class FlashObject {    private String name;    priv ...

  9. Ubuntu20.04linux内核(5.4.0版本)编译准备与实现过程-编译前准备(1)

    最近项目也和linux kernel技术有关,调试内核和内核模块.修改内核源码,是学习内核的重要技术手段之一.应用这些技术时,都有一本基本的要求,那就是编译内核.因此,在分析内核调试技术之前,本随笔给 ...

  10. markdown快捷输入

    标题: 输入方式:#+空格+标题名,几级标题就敲几个# 注:最大支持六级标题 字体 加粗:在要加粗的字体前后加** 斜体:在要倾斜的字体前后加* 斜体加粗:在要倾斜并加粗的字体前后加*** 删除线:在 ...