spring的rmi整合以及客户端和服务端搭建1.0

最近接手了个项目,领导让用spring的rmi来实现,并且需要高并发的(这个放到后面研究吧)

由于之前的通讯一直使用的是简单的http+json或者http+xml来实现的;这次接到这个任务后,首先要弄明白rmi的工作原理;

看了下很多大牛以及相关文档的分享,很是感动!

以下这段是借鉴转载的:这个大牛的

Spring整合RMI的原理

客户端的核心是RmiProxyFactoryBean,包含serviceURL属性和serviceInterface属性。

通过JRMP访问服务。JRMP JRMP:java remote method protocol,Java特有的,基于流的协议。

服务端暴露远程服务

RmiServiceExporter把任何Spring管理的Bean输出成一个RMI服务。通过把Bean包装在一个适配器类中工作。适配器类被绑定到RMI注册表中,并且将请求代理给服务类。

到这spring的rmi原理大致了解了一些;spring这个轻量级的框架真的很棒,~\(≧▽≦)/~

替我们做了很多事,否则我们就要自己动手来进行rmi的注册和发布。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RMI(Remote Method Invocation) 是 Java 中的一种远程方法调用机制,它允许在分布式系统中通过网络访问远程对象,使得程序员可以像调用本地对象一样调用远程对象的方法。下面我将为您提供一个简单的 RMI 客户端服务端开发实例。 1. 编写服务端代码 首先,我们需要编写一个服务端 Java 类,该类需要实现一个远程接口。在该接口中,我们定义了一个 `getMessage` 方法,用于返回一个字符串信息。 ```java import java.rmi.Remote; import java.rmi.RemoteException; public interface Message extends Remote { public String getMessage() throws RemoteException; } ``` 接着,在服务端代码中,我们需要实现这个接口,提供相应的实现逻辑。在这个例子中,我们简单地返回了一个字符串信息。 ```java import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; public class MessageImpl extends UnicastRemoteObject implements Message { public MessageImpl() throws RemoteException { super(); } public String getMessage() throws RemoteException { return "Hello, RMI!"; } } ``` 2. 启动 RMI 服务 在服务端代码中,我们需要启动一个 RMI 服务,使得客户端可以通过网络访问到远程对象。在这个例子中,我们使用 `LocateRegistry.createRegistry` 方法创建了一个 RMI 注册表,并在该注册表中绑定了一个名为 "Message" 的远程对象。 ```java import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; public class Server { public static void main(String args[]) { try { MessageImpl obj = new MessageImpl(); Registry registry = LocateRegistry.createRegistry(1099); registry.rebind("Message", obj); System.out.println("Server started."); } catch (Exception e) { System.out.println("Server exception: " + e.getMessage()); e.printStackTrace(); } } } ``` 3. 编写客户端代码 在客户端代码中,我们需要通过 RMI 注册表查找远程对象,并调用其方法。在这个例子中,我们查找了名为 "Message" 的远程对象,并调用了其 `getMessage` 方法。 ```java import java.rmi.registry.LocateRegistry; import java.rmi.registry.Registry; public class Client { public static void main(String args[]) { try { Registry registry = LocateRegistry.getRegistry("localhost"); Message stub = (Message) registry.lookup("Message"); String response = stub.getMessage(); System.out.println("Response: " + response); } catch (Exception e) { System.out.println("Client exception: " + e.getMessage()); e.printStackTrace(); } } } ``` 4. 运行程序 最后,我们需要在命令行中依次运行服务端程序和客户端程序,以启动 RMI 服务并访问远程对象。 ``` # 启动服务端 $ java Server # 启动客户端 $ java Client ``` 输出结果为: ``` Server started. Response: Hello, RMI! ``` 以上就是一个简单的 RMI 客户端服务端开发实例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值