java RMI的意义,及小例子


RMI的意义

定义: RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。也可以说成分布式计算、可以远程调用方法。

到底有什么作用,看下面的小例子

例子:比如你有一台支持Java的手机 还有一台台式机 手机上有一个非常复杂的运算 如果用手机

来计算的话可能需要很长时间、不过如果用台式机的话几秒就结束了,这个时候就是RMI大显神通的时候,使用RMI从手机发送请求 然后交给台式机计算 然后台式机返回计算和的结果

第一步:创建一个远程接口

package com.javaer.examples.socket.rmi;
 
import java.rmi.Remote;
import java.rmi.RemoteException;
//创建远程接口及声明远程方法
public interface HiInterface extends Remote      {
	  /**    
	    * 远程接口方法必须抛出 java.rmi.RemoteException    
	    */    
	   public String speak() throws RemoteException;     
}

第二步:创建远程方法

package com.javaer.examples.socket.rmi;
 
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
//实现远程接口及远程方法(继承UnicastRemoteObject)
public class Hi extends UnicastRemoteObject implements HiInterface {
 
	private String message;
 
	public Hi(String msg) throws RemoteException {
		super();
		message = msg + " I am on server....";
 
	}
	@Override
	public String speak() throws RemoteException {
		return message;
	}
 
}

第三步:实现远程Server

package com.javaer.examples.socket.rmi;
 
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
 
//启动RMI注册服务,并注册远程对象(HiServer.java)
public class HiServer {
 
	 public static void main(String[] argv)     
	   {     
	      try    
	      {     
	         //启动RMI注册服务,指定端口为1099 (1099为默认端口)     
	         //也可以通过命令 $java_home/bin/rmiregistry 1099启动     
	         //这里用这种方式避免了再打开一个DOS窗口     
	         //而且用命令rmiregistry启动注册服务还必须事先用RMIC生成一个stub类为它所用     
	         LocateRegistry.createRegistry(1099);     
 
	         //创建远程对象的一个或多个实例,下面是hello对象     
	         //可以用不同名字注册不同的实例     
	         HiInterface hi = new Hi("Hello, world!");     
 
	         //把hi注册到RMI注册服务器上,命名为A
	         Naming.rebind("A", hi);     //客户端通过这个A来寻找
 
	         //如果要把hi实例注册到另一台启动了RMI注册服务的机器上     
	         //Naming.rebind("//192.168.1.105:1099/A",hi);     
 
	         System.out.println("Hi Server is ready.");     
	      }     
	      catch (Exception e)     
	      {     
	         System.out.println("Hi Server failed: " + e);     
	      }     
	   }     
 
}

第四步:实现本地Client

package com.javaer.examples.socket.rmi;
 
import java.rmi.Naming;
 
public class HiClient {
	/**    
	    * 查找远程对象并调用远程方法    
	    */    
	   public static void main(String[] argv)     
	   {     
	      try    
	      {     
	         //HiInterface hi = (HiInterface) Naming.lookup("A");     
 
	         //如果要从另一台启动了RMI注册服务的机器上查找hello实例     
	    	  HiInterface hi = (HiInterface)Naming.lookup("//192.168.1.100:1099/A");     
	         //调用远程方法     
	         System.out.println(hi.speak());     
	      }     
	      catch (Exception e)     
	      {     
	         System.out.println("HiClient exception: " + e);     
	      }     
	   }     
}

将四个文件编译出来一个RMI.jar

拷贝在服务器端执行
java -classpath RMI.jar com.javaer.examples.socket.rmi.HiServer
Hi Server is ready.

拷贝在客户端执行
java -classpath RMI.jar com.javaer.examples.socket.rmi.HiClient
Hello, world! I am on server....

当然,全部在本地开两个窗口也可以测试的。当时改Nutch的时候,老看到这种远程调用,当时摸不着头脑,看来当时先看看RMI,就对Nutch分布式有更深入的了解了。

如果你是一名技术人员可加我QQ 2651-0442-02,如果你是java技术人还可以加入QQ群 1784-9136-0
你将得到的不仅仅是技术的交流,还有职业机会,人生解惑.
首发地址:月小升博客https://java-er.com/blog/java-rmi-example/
无特殊说明,文章均为月小升原创,欢迎转载,转载请注明本文地址,谢谢
此条目发表在 JAVA 分类目录,贴了 , 标签。将固定链接加入收藏夹。
既然来了,就评论一下,不会怀孕的

发表评论

电子邮件地址不会被公开。 必填项已用 * 标注

*

您可以使用这些 HTML 标签和属性: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong> <pre lang="" line="" escaped="" highlight="">