Java RMI-IIOP 入门

 RMI-IIOP 出现以前,只有 RMI 和 CORBA 两种选择来进行分布式程序设计。RMI-IIOP 综合了 RMI 和CORBA 的优点,克服了他们的缺点,使得程序员能更方便的编写分布式程序设计,实现分布式计算。

  首先,RMI-IIOP 综合了 RMI 的简单性和 CORBA 的多语言性(兼容性),其次 RMI-IIOP 克服了 RMI 只能用于 Java 的缺点和 CORBA 的复杂性(可以不用掌握 IDL)。下面给出了一个非常的简单的 RMI-IIOP 程序。

  1. 实现远程接口,生成远程对象,存根(Stub)和框架(Skeleton)

  实现远程接口,远程接口告诉 JVM:实现了该接口的对象可以远程调用及有哪些方法可以调用。本例子中定义了 sayHello()。由于远程调用会涉及到网络通讯,因此这些方法都要抛出 RemoteException。远程接口和远程对象可以由 A 开发,并把远程接口 (Hello)d 打包分给 Client 端开发者B。

  建立 f:/mi_iiop 目录,把 Hello.java 和 HelloImpl.java 拷贝到该目录中。

  // Hello.java
  package jdeveloper.rmi;

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

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

  生成远程对象.
  // HelloImpl.java
  package jdeveloper.rmi_iiop;

  import javax.naming.*;

  import java.rmi.RemoteException;
  import java.rmi.RMISecurityManager;
  //import java.rmi.server.UnicastRemoteObject;
  import javax.rmi.PortableRemoteObject;

  public class HelloImpl extends PortableRemoteObject implements Hello {
    public HelloImpl() throws RemoteException {
      super();
    }

    public String sayHello() {
      return "Hello World!";
    }

    public static void main(String args[]) {

      // Create and install a security manager
      if (System.getSecurityManager() == null) {
        System.setSecurityManager(new RMISecurityManager());
      }
      try {
        Hello obj = new HelloImpl();
        // Bind this object instance to the name "HelloServer"
        //***** old code for rmi
        // Naming.rebind("HelloServer", obj);
  
        //***** new code for rmi-iiop
        Context initialNamingContext = new InitialContext();
        initialNamingContext.rebind("HelloServer", obj);
   
        System.out.println("HelloServer bound in registry");
      } catch (Exception e) {
        System.out.println("HelloImpl err: " + e.getMessage());
        e.printStackTrace();
      }
    }
  }

  存根(Stub)和框架(Skeleton)

  f:
  cd
  mi_iiop
  set classpath=.;%classpath%
  javac -d . Hello.java
  javac -d . HelloImpl.java
  rmic -iiop -d . jdeveloper.rmi_iiop.HelloImpl
  这一步将生成<_Interface>_stub.class,<_InterfaceImpl>_Tie.class:
  _Hello_Stub.class和_HelloImpl_Tie.class

  2. 实现 Client 端程序

  // HelloClient.java
  package jdeveloper.rmi_iiop;

  import java.rmi.RMISecurityManager;
  import java.rmi.Naming;
  import java.rmi.RemoteException;
  import java.rmi.NotBoundException;

  import javax.rmi.PortableRemoteObject;
  import javax.naming.*;

  public class HelloClient {
    public static void main(String args[]) throws Exception{
      System.setSecurityManager(new RMISecurityManager());
      Context initialNamingContext = new InitialContext();
      Hello RemoteObj = (Hello) PortableRemoteObject.narrow(
        initialNamingContext.lookup("iiop://"+ args[0] +"/HelloServer"),
        Hello.class
      );
      System.out.println(RemoteObj.sayHello());
    }
  }

  把 HelloClient.java 拷贝到目录 f:/mi_iiop 中。
  f:
  cd
  mi_iiop
  javac -d . HelloClient.java

  3. 运行程序

  启动 DOS 窗口

  运行 tnameserv

  把 server.bat 和 policy 放到 f:/mi_iiop

  启动新的 DOS 窗口

  运行 server


  启动新 的DOS 窗口

  把 client.bat 放到 f:/mi_iiop

  运行 client hostname

  server.bat
  set CP=%classpath%
  set classpath=.;%classpath%
  java -Djava.naming.factory.initial=com.sun.jndi.cosnaming.CNCtxFactory
  -Djava.naming.provider.url=iiop://hjc:900 -Djava.security.policy=policy   jdeveloper.rmi_iiop.HelloImpl
  set classpath=%CP%
  client.bat
  set CP=%classpath%
  set classpath=.;%classpath%
  java -Djava.naming.factory.initial=com.sun.jndi.cosnaming.CNCtxFactory
  -Djava.naming.provider.url=iiop://hjc:900 -Djava.security.policy=policy   jdeveloper.rmi_iiop.HelloClient %1
  set classpath=%CP%
  policy
  grant {
  // Allow everything for now
  permission java.security.AllPermission; 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值