Java RMI:InitialContext.lookup()的工作原理

时间:2016-02-09 08:39:45

标签: java ejb rmi

在分布式客户端服务器应用程序中,我使用java RMI从客户端计算机调用服务器端方法。在服务器端,正在使用EJB,而应用程序服务器是Glassfish。我在服务器端有一个SampleFacade类,它是一个java会话bean,SampleFacadeRemote是一个暴露给客户端的远程接口(@Remote已经与它一起使用)。 SampleFacade实现了SampleFacadeRemote接口。

请查看以下代码段:

        private static SampleFacadeRemote lookupSampleFacade()
        {
            Context c = new InitialContext();
            return (SampleFacadeRemote)c.lookup("java:comp/env/SampleFacade");
        }
        catch (NamingException ne)
       {
          throw new RuntimeException(ne);
       }

这里,使用返回的对象,可以成功执行远程方法。

我很想知道它是如何工作的。 lookup方法是否将SampleFacade对象返回给客户端以执行其方法?但是SampleFacade的方法假设在服务器端/远程JVM上运行。然后lookup()方法返回什么类型的对象?请解释一下潜在的机制。

1 个答案:

答案 0 :(得分:3)

它返回一个存根:一个客户端对象,它实现了相同的远程接口,并知道如何与实际的远程对象进行通信。

实际上你应该注意到,lookup()方法不是执行这种魔法的方法:它最终是有关的bind()方法,甚至是对象本身,它将远程对象转换为存根,除非存根是传递给bind()的存根。换句话说,存根已经在注册表或LDAP中或者您正在查找的任何内容中,lookup()只会为您提供所找到的任何内容。