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



在分布式客户端服务器应用程序中,我正在使用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);
       }

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

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

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

事实上,您应该注意,执行此魔术的不是lookup()方法:最终是远程对象本身将自身转换为其存根。存根已经在注册表或LDAP或您正在查找的任何内容中,lookup()只是为您提供找到的任何内容。

最新更新