this is a extra element for clear the floated element
JavaRMI-IIOP入门
  • 12/31
  • 2008
Rmi/Corba/Jini | Java 2773 次查看
  RMI-IIOP出现以前,只有RMI和CORBA两种选择来进行分布式程序设计。RMI-IIOP综合了RMI和CORBA的优点,克服了他们的缺点,使得程序员能更方便的编写分布式程序设计,实现分布式计算。

  首先,RMI-IIOP综合了RMI的简单性和CORBA的多语言性(兼容性),其次RMI-IIOP克服了RMI只能用于Java的缺点和CORBA的复杂性(可以不用掌握IDL).

  下面给出了一个非常的简单的RMI-IIOP程序,该程序是在上一个例子(Java2 RMI入门的基础)上修改完成的,可以对比两个程序的区别。

  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;