转自:http://georid.spaces.live.com/blog/cns!BD176951AD9B69BF!741.entry
先来了解一下:
RPC(Remote Procedure Call)远程调用
RPC是在客户端/服务器端(client/server)网页或软件编程中不可缺少的一种方法,client若需要对数据进行处理时,先创建一个提出问题的进程(procedure),进程采用将操作以请求的方式发送给服务器,并等待服务器端对请求做出响应并给出回复,不需要在client端去实地的进行数据处理和复杂的运算,而是将这些过程交给服务器去做,这个client端的进程只是等待,等待会有两种可能的结果:一种是由服务器端传回计算或处理的结果;二是操作超时,并未收到从服务器端发来的回复,但无论是哪一种情况发生,client端进程都算完成使命并自行结束。从编程的角度讲,打个比方,在网上购物的购物篮功能中,将选购的物品放入购物篮的操作就会使用到RPC,在客户端所表现的只是需要点击一个按钮,按钮的功能是将选定的物品放入购物篮中。这是在前台,用户可以确实的看到的操作;而在后台,在编辑这个网页的过程中,用户点击按钮的这一步,是由远程调用服务器端的相应的函数实现的。在此例中,想实现这个按钮的功能就要知道调用服务器端的添加物品的函数(也叫接口interface)的名称--AddinBasket();client端发送请求给服务器,要将选定的物品放入购物篮,服务器端接到请求后,由AddinBasket函数对请求进行响应,做出处理,然后把响应结果(如,物品已放入购物篮)返回给client端。Client端接到回复后显示给用户:操作成功,物品已加入购物篮。
那么一次RPC在计算机的内部又是如何进行的呢?“远程”调用是怎么调用实现的?
还拿上面的例子:
client端,用户点击按钮后,在client本地建立一个进程A(procedure A),进程的目的是想将一本书(book)放入购物篮,进程A将这本书放入本地的内存地址中(进程A本身并不会直接去产生调用远程服务器端的请求,而是和在本地操作一样只是将数据存储到内存中,由其它进程进行处理,将结果保存到内存中),然后进入等待状态,client端的client-stub检测到进程A在内存中存储的数据后,从内存中将数据读取出来连同需要调用的函数AddinBasket函数名一起建立一个数据包发送给服务器端的 server-stub程序。
server端,server-stub收到client-stub发送过来的数据包后,打开数据包,从里面读出数据,将数据存储到 server的内存中,server端的处理进程procedure B检测到server端由server-stub存储的数据后,调用server端的AddinBasket函数,处理数据,并将结果存入server端的内存,通知server-stub数据处理完毕,server-stub从内存中读取出处理结果,制作一个数据包作为client端请求的回复发送给 client-stub。自此server端的运行完毕。
client端,client-stub接收到数据包,从中读取出处理结果的数据,保存到client端的内存中并通知进程A数据处理完毕。进程A从内存中读取结果。这样一次远程调用彻底结束。在这个过程中,client端的进程A以及server端的进程B都不知道他们要进行的是一个远程的调用或请求,而是一直当作本地的操作一样,从各自本地的内存中读取数据,而client-stub和server-stub是实现这个远程调用的具体实施者。这种客户端向服务器端发送请求,由服务器相应处理传回结果的方法被称为RPC(远程调用)。
因为需要调用服务器端的接口函数就需要了解服务器端究竟提供了什么样的接口,接口的实现方法是什么,函数的参数是什么类型的,这些信息都会写在服务器端的函数文档中,如上面的购物篮功能涉及的函数不光有:AddinBasket()还应该包括,RemovefromBasket(),ClearBasket(),getBasketItem(),purchasBasket()等等这些,这些也就是相对于客户的“从购物篮中删除物品”,“清空购物篮”,“获得购物篮中的物品列表”,“为购物篮内物品付款”的这些具体的操作的响应函数,编程人员在编写页面的代码时需要透彻的理解各个函数的调用方法,以及相互之间的逻辑关系。这里的逻辑关系是指如例中,当购物篮内是空的时,从购物篮中删除物品的按钮应该是不允许操作状态的。这一系列的函数的理解都给编程增添了复杂度,而且服务器端在正式运行中要处理所有的用户请求,而这些请求的功能是很烦琐的,这给服务器端无形中创造了很多的工作量,而REST在这一点上是很精简有效的。
现在我们来看:
REST(Representational Status Transfer)
必须承认的是大部分的REST的实现中使用了RPC的机制,它也有client端和server端,所不同于RPC的是,它的响应函数简单来讲就是get函数和post函数,对于上面使用的购物篮问题中使用REST方法实现的化,只需要两个函数getBasket和PostBasket,getBasket 函数是将服务器端当前的购物篮状态获取下来,client端想对购物篮中的物品做出操作的话,比如添加一本书,或将已经有的物品取出购物篮,直接修改修改购物篮中的物品,最后将一个新的购物篮内物品的状态(status)用postBasket方法发送给服务器。这就是REST的中心原理,即:下载服务器端的当前状态,修改之后将最终用户所期待的状态发送给服务器,服务器按照客户的期待进行修改。而不同于RPC的也就是响应函数没有那么多的,复杂的逻辑关系,函数也减少了很多,只是get和post两个。从而给服务器减少了工作量而且在逻辑上也是符合的。表面上看来REST比RPC是要先进的,但是 REST的缺点在于,这种只有get和post的逻辑并不是永远有效的,并不是对一切问题都是万能的,举个例子来说:两个用户A和B使用同一个账户在网上商店购物,他们都从服务器端获得了当前购物篮中的状态,用户A向购物篮中添加了一本书,用户B在购物篮中添加了一辆自行车,随后A先向购物篮状态上传给服务器,此时服务器中购物篮里多出了一本书,此时B也把他的购物篮上传给服务器,服务器将B的购物篮状态覆盖了原有的状态,购物篮里多了一辆自行车,而A挑选的一本书在B上传后购物篮覆盖过程中被丢失了。这就造成了对用户的操作的不完全服从。这一点也成了REST的缺点。
总结一下,RPC逻辑复杂,对服务器造成很多的工作量,但分工明确,不容易造成失误。REST逻辑简单,对服务器的工作压力也比较小,但在某些特殊情况下不一定完美的解决问题。
- 浏览: 497014 次
- 性别:
- 来自: 武汉
相关推荐
### REST与RPC的区别详解 #### 一、概述 在现代软件开发中,特别是分布式系统设计领域,REST(Representational State Transfer)与RPC(Remote Procedure Call)是两种非常重要的服务调用方式。这两种方法各有...
在标题和描述中提到的“dubbo rest rpc相关jar包”是指Dubbo支持RESTful API调用的扩展模块,这使得Dubbo能够与更广泛的Web服务和微服务生态系统集成。 首先,我们来详细了解一下`dubbo-2.8.4.jar`。这是Dubbo的...
java运行依赖jar包
Armeria是一个强大的开源项目,专门设计用于构建高性能、异步的RPC(远程过程调用)和REST(Representational State Transfer)服务。它基于Java 8、Netty、HTTP/2和gRPC技术栈,提供了现代化的网络应用开发框架。...
gem install json-rpc2rest 或将以下行添加到 Gemfile: gem 'json-rpc2rest' 并从您的 shell 运行bundle install 。 之后添加行到config/application.rb config . middleware . use 'Json-Rpc2Rest' 您也...
smart-doc是一款同时支持JAVA REST API和Apache Dubbo RPC接口文档生成的工具,smart-doc在业内率先提出基于JAVA泛型定义推导的理念, 完全基于接口源码来分析生成接口文档,不采用任何注解侵入到业务代码中
rest_rpc c++11, high performance, cross platform, easy to use rpc framework. It's so easy to love RPC. Modern C++开发的RPC库就是这么简单好用! rest_rpc简介 rest_rpc是一个高性能、易用、跨平台、header ...
`rest_rpc`是一个基于C++11开发的轻量级RPC(Remote Procedure Call)框架,它将RESTful API的设计理念与RPC技术相结合,为开发者提供了一种简单且高效的远程调用解决方案。本文将深入探讨`rest_rpc`的核心特性、...
Dubbo 是阿里巴巴开源的一款高性能、轻量级的 Java RPC 框架,它极大地简化了分布式服务开发的流程,使得服务提供者和服务消费者之间的通信变得简单。在现代微服务架构中,REST(Representational State Transfer)...
Armeria是一个强大的开源项目,专门设计用于构建高性能的异步RPC和REST服务。它建立在Java 8、Netty、HTTP/2、Thrift和gRPC这些技术的基础之上,为开发者提供了丰富的功能和高效的性能。 **Java 8**: Armeria充分...
java运行依赖jar包
Web 服务协议如 SOAP、REST 和 XML-RPC 提供了将这些遗留应用程序与网络集成的途径。本文主要关注 XML-RPC,这是一种简单且轻量级的消息传递协议,支持基于 XML 的跨平台通信,特别适合 C++ 应用程序。 **为什么要...
REST 、DO、RPC之间区别对比 REST与CORBA、SNMP、SOAP比较 腾讯开放平台REST API 示例 通过URL来设计系统结构,抽象的是资源,而不是对象、过程,完成的是用户接口 REST API的开发框架介绍:JSR-311,REST Web ...
- **异构系统集成**:PHP RPC可以用于连接不同编程语言的系统,如PHP与Python、Java等。 **文件内容** - **AUTHORS**:列出项目的主要作者和贡献者,提供了关于开发者的相关信息。 - **INSTALL**:包含了安装和...
目前在三种主流的Web服务实现方案中,因为REST模式的Web服务与复杂的SOAP和XML-RPC对比来讲明显的更加简洁,越来越多的web服务开始采用REST风格设计和实现。例如,Amazon.com提供接近REST风格的Web服务进行图书查找...
在理解REST时,应避免将其与RPC(Remote Procedure Call)简单等同,因为REST不仅仅是一系列HTTP方法的简单应用。 REST的核心理念在于资源的抽象、统一的接口以及状态的无状态传输。其中,“资源”指的是通过网络可...
1. **微服务架构**:微服务架构的核心思想是将单一应用程序分解为一组小型服务,每个服务都在其自身的进程中运行,服务之间通过轻量级的方式(如 HTTP/REST 或者 RPC)进行通信。这种解耦的设计提高了系统的可扩展性...
它具有与该样板相同的所有功能: REST API的框架用户管理使用访问控制。 该样板扩展了该代码,以提供成为IPFS网络上的“服务提供商”所需的基本功能。 如果您不熟悉IPFS上提供的服务概念,请参阅。 这些基本功能...