Java RMI的简单例子

Posted on 2007-05-26 09:41 E.ven 阅读(28177) 评论(6)  编辑  收藏
 

现在虽然我们很少用到RMI进行编程,但是做为Java一个最早的分布式解决方案,我们还是有了解的必要,从例子开始吧(虽然是几年前的了)!

远程接口RmiHelloRemoteIntfc .java

import java.rmi.*;

public interface RmiHelloRemoteIntfc extends Remote
{
   String helloRemoteObj(String client) throws RemoteException;
}

远程接口的实现类RmiHelloRemoteObj.java

import java.rmi.server.*;
import java.rmi.*;

public class RmiHelloRemoteObj extends UnicastRemoteObject implements RmiHelloRemoteIntfc
{

  public RmiHelloRemoteObj() throws RemoteException
  {
    super();
  }

  public String helloRemoteObj(String client) throws RemoteException
  {
     return "Hello World"+client;
  }

}

服务器类RmiHelloServer.java

import java.io.*;
import java.rmi.*;
import java.rmi.server.*;
import sun.applet.*;
import java.rmi.registry.LocateRegistry;

public class RmiHelloServer
{

  public RmiHelloServer()
  {
  }
  public static void main(String[] args)
  {
    //创建并安装安全管理器
    if(System.getSecurityManager()==null)
    {
       System.setSecurityManager(new RMISecurityManager());
    }

    try{
         //创建远程对象
         RmiHelloRemoteObj ttt=new RmiHelloRemoteObj();
         //启动注册表
         LocateRegistry.createRegistry(2222);
         //奖名称绑定到对象
         Naming.rebind("//Fangm:2222/helloObj",ttt);

         System.out.println("RMI服务器正在运行。。。。。。");
      }
      catch(Exception e)
      {
         e.printStackTrace();
      }


  }
}

服务器端的权限文件RmiHelloServer.policy

grant codeBase
"file:/e:/download/rmitest/"
{
 permission java.net.SocketPermission
      "*:1000-9999","accept,connect,listen,resolve";
};

 

现在就看看Client端是如何连接服务器和进行远程方法的调用的吧

import java.rmi.*;
import java.rmi.server.*;

public class RmiHelloClient
{

  public RmiHelloClient()
  {
  }
  public static void main(String[] args)
  {
    //创建并安装安全管理器
    if(System.getSecurityManager()==null)
    {
       System.setSecurityManager(new RMISecurityManager());
    }

    try{
          RmiHelloRemoteIntfc c1=(RmiHelloRemoteIntfc)Naming.lookup("rmi://Fangm:2222/helloObj");
          System.out.println(c1.helloRemoteObj("Everyone"));
    }
    catch(Exception e)
    {
       e.printStackTrace();
    }
    System.exit(0);

 

  }
}

Client端的权限文件RmiHelloClient.policy

grant codeBase
"file:/e:/download/rmitest/"
{
  permission java.net.SocketPermission
      "*:1000-9999","accept,connect,listen,resolve";
};

好了,一个最简单的RMI例子就安无了,对了还少了最重要的一步,那就是编译和运行呢?我们就来了个Bat或Cmd的批处理来进行吧,

看看RmiHello.bat吧

javac RmiHelloRemoteIntfc.java

javac RmiHelloRemoteObj.java

rmic RmiHelloRemoteObj

javac RmiHelloServer.java

javac RmiHelloClient.java

echo 在另一个窗口启动服务器,请稍后。。。
start java  -Djava.security.policy=RmiHelloServer.policy RmiHelloServer

echo 运行客户程序。。。
java -Djava.security.policy=RmiHelloClient.policy RmiHelloClient

这个文件很简单吧!包你一试就通,虽然简单,不过对于初学者来说,还是很不错的哦!

Feedback

# re: Java RMI的简单例子  回复  更多评论   

2008-06-12 08:18 by
那现在用什么啊

# re: Java RMI的简单例子  回复  更多评论   

2008-07-31 15:40 by 嘉宝
是啊
那现在用什么技术实现分布式

# re: Java RMI的简单例子[未登录]  回复  更多评论   

2008-09-12 14:46 by apple0668
rmi结合spring提供接口,用起来更加方便了

# re: Java RMI的简单例子  回复  更多评论   

2009-06-22 13:28 by 真晕啊
#&%(*&!@(#^!@(*#(!@#
给一个错误的例子来误导我!
注册表的端口号跟主机端口号对不上的,主机地址又不知道是什么东东来的

# re: Java RMI的简单例子[未登录]  回复  更多评论   

2010-01-13 15:36 by haha
@真晕啊
不是别人误导你 而是你自己学而不精阿。艾

# re: Java RMI的简单例子  回复  更多评论   

2012-08-23 19:27 by 李锋

只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问  
 

posts - 27, comments - 15, trackbacks - 0, articles - 1

Copyright © E.ven