在分布式客户端服务器应用程序中,我正在使用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()
只是为您提供找到的任何内容。