java多线程    Java入门    vsftp    ftp    linux配置    centos    FRP教程    HBase    Html5缓存    webp    zabbix    分布式    neo4j图数据库    

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分布式有更深入的了解了。


This entry was posted in JAVA and tagged , . Bookmark the permalink.
月小升QQ 2651044202, 技术交流QQ群 178491360
首发地址:月小升博客https://java-er.com/blog/java-rmi-example/
无特殊说明,文章均为月小升原创,欢迎转载,转载请注明本文地址,谢谢
您的评论是我写作的动力.

Leave a Reply