跟《HeadFirst设计模式》中一样,我也不准备讲普通的代理模式,而要专门介绍一下Java的远程代理,也就是RMI。
远程代理的类图很简单,只有一个接口和一个实现类:
DuckServer是一个继承了Remote的接口,其中有一个等待实现的quack方法。Duck是DuckServer的实现类,继承自UnicastRemoteObject。
Duck中有一个程序主方法main,这样Duck是一个可执行的Java类。main方法中注册了DuckServer远程服务:
publicstatic void main(String[] args) {
try{
DuckServerduckServer = new Duck();
Naming.rebind("DuckServer",duckServer);
}catch (RemoteException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}catch (MalformedURLException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}
}
以下的代码用来调用远程服务:
publicvoid testQuack() {
try{
DuckServerduckServer = (DuckServer)Naming.lookup("rmi://127.0.0.1/DuckServer");
Strings = duckServer.quack();
System.out.println(s);
}catch (MalformedURLException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}catch (RemoteException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}catch (NotBoundException e) {
//TODO Auto-generated catch block
e.printStackTrace();
}
}
当然,在调用远程服务前需要先运行rmiregistry服务,并运行远程代理的服务端(在本例子中,即Duck类)。
顺便提一句,RMI和Hadoop结合可以创建非常强大的分布式应用。