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

Java RMI : how InitialContext.lookup() works

在分布式客户端服务器应用程序中,我使用 java RMI 从客户端计算机调用服务器端方法。在服务器端使用 EJB,应用服务器是 Glassfish。我在服务器端有一个 SampleFacade Class,它是一个 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);
       }

这里,有了returned对象,远程方法就可以成功执行了。

我很想知道它是如何工作的。查找方法 return SampleFacade 是否向客户端对象以执行其方法?但是 SampleFacade 的方法应该是 运行 在服务器 side/Remote JVM 上。那么 lookup() 方法正在 return 编辑什么类型的对象?请解释基本机制。

它 returns 存根:实现相同远程接口并知道如何与实际远程对象通信的客户端对象。

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