RMI(二)——Java RMI协议开发

from:http://bbs.star-bbs.net/viewthread.php?tid=53934
Java RMI协议开发
在Java的开发中,Web端只是以个较小的亮点,抛开HTTP协议,Java世界里还有很多比较牛×的技术,但做为J2EE的核心技术,RMI协议就显得由为重要,RMI对搞过EJB的人来说应该不陌生,但EJB是在RMI和CORBA的基础之上进行了封装(也就是RMI//IIOP),程序员往往不用接触底层.做为Java工程师,对J2EE最核心的技术-----EJB的心脏 RMI自然是要非常熟悉.

RMI的编程模型是采用框架和桩的模式,基本原理如下:
客户请求------>(rmi协议)---------->远程框架(注册机)------------>远程对象----------(处理)--------->结果返回到框架--------->客户

1. 服务器端创建远程接口和实现远程接口的类
2. 通过RMIC命令(%java_home%/bin/rmic.exe)来编译远程接口实现类从而生成 stub等文件.
3. 运行 rmiregistry命令(%java_home%/bin/rmiregistry.exe) 来启动RMI远程注册机
4. 向RMI注册机注册远程对象供客户端调用


下面来个实实在在的例子,大家回去根据效果自己领悟,写理论我不在行

1. 首先 建立以个远程接口 Mclaren.java
package com.skylink.rmi;

import java.rmi.Remote;
import java.rmi.RemoteException;

public interface Mclaren extends Remote{
public String sayHello(String username) throws RemoteException;
}

2.建立以个远程接口实现类,来做为RMI服务提供方 MclarenServer.java
package com.skylink.rmi;

import java.rmi.RemoteException;
import java.rmi.Naming;
import java.rmi.server.UnicastRemoteObject;

pulic class MclarenServer extends UnicastRemoteObject {
public MclarenServer() throws RemoteException {
super();
}
public void registry(String name){
try{
System.setSecurityManager(new RMISecurityManager());
Naming.rebind(name,this);
}catch(Exception e)[
e.printStackTrace();
}
}
public String sayHello(String username){
return "输出为 : "+username;
}
}

3 建立用来启动服务器的类 StartServer.java

package com.skylink.rmi;
public class StartServer{
public static void main(String[] args){
try{
System.setSecurityManager(new RMISecurityManager());
new MclarenServer().registry("//192.168.0.192:1099/Mclaren");
System.out.println("服务已经注册..");
}catch(Exception e){
e.printStackTrace();
}
}

*
……
【阅读全文】
原文地址:https://www.cnblogs.com/dkblog/p/1980820.html