29、远程服务开发:Spring 助力下的高效实践

远程服务开发:Spring 助力下的高效实践

在软件开发的世界里,很多应用程序就像被困在荒岛上的人。表面上看,它们似乎能够自给自足,但实际上,它们可能需要与组织内部或外部的其他系统进行协作。就如同荒岛上的人不能仅仅依靠椰子和鱼生存,最终需要与外界取得联系获取食物、衣物和其他物资一样,应用程序也需要与其他系统通信以远程访问服务。

1. Spring 远程调用概述

远程调用是客户端应用程序与服务之间的交互。当客户端应用程序需要某些超出其自身功能范围的功能时,它会向能够提供该功能的其他系统发出请求。远程应用程序通过远程服务来暴露这些功能。

以 Spitter 应用程序为例,除了现有的基于浏览器的用户界面,我们可能还希望为其开发桌面或移动前端。为了实现这一目标,我们需要将 SpitterService 接口的基本功能作为远程服务暴露出来。

远程过程调用(RPC)是客户端应用程序与 Spitter 之间交互的起点。从表面上看,RPC 类似于对本地对象方法的调用,都是同步操作,会阻塞调用代码的执行,直到被调用的过程完成。但两者的区别在于调用的距离,就像人与人之间的交流一样,如果在办公室的饮水机旁讨论周末足球比赛的结果,这是本地对话;而如果拿起电话给另一个城市的客户打电话,则是远程对话。同样,本地方法调用是在同一应用程序内的代码块之间交换执行流,而 RPC 是将执行流从一个应用程序传递到另一个理论上位于远程位置的不同机器上的应用程序。

Spring 支持多种不同的 RPC 模型,包括远程方法调用(RMI)、Caucho 的 Hessian 和 Burlap,以及 Spring 自己的 HTTP 调用器。以下是这些模型及其适用场景的概述:
| R

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值