6

有人可以给出一个简单的 RMI 回调示例 Hello World 吗?我一直在尝试研究它,但我似乎无法找到我理解的一个。我不明白回调是/做什么。

这是我目前的 Hello World RMI,如果它有帮助的话......

界面

package example.hello;

import java.rmi.Remote;
import java.rmi.RemoteException;

public interface Hello extends Remote {
    String sayHello() throws RemoteException;
}

客户

package example.hello;

import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class Client {

    private Client(){}

    public static void main(String[] args){

        String host = (args.length < 1) ? null : args[0];

        try{
            Registry registry = LocateRegistry.getRegistry(host);
            Hello stub = (Hello) registry.lookup("Hello");
            String response = stub.sayHello();
            System.out.println("response: " + response);
        } catch (Exception e) {
            System.err.println("Client exception: " + e.toString());
            e.printStackTrace();
        }
    }

}

服务器

package example.hello;

import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.rmi.server.UnicastRemoteObject;

public class Server implements Hello {

    public Server(){}

    @Override
    public String sayHello() {
        System.out.println("responded!");
        return "Hello, world!";
    }

    public static void main(String[] args) {

        try{
            Server obj = new Server();
            Hello stub = (Hello) UnicastRemoteObject.exportObject(obj, 0);

            // Bind the remote object's stub in the registry
            Registry registry = LocateRegistry.getRegistry();
            registry.bind("Hello", stub);

            System.err.println("Server ready");
        } catch (Exception e) {
            System.err.println("Server exception: " + e.toString());
            e.printStackTrace();
        }
    }
}
4

1 回答 1

17

我不是 RMI 方面的专家,但我可以告诉你的是,你可以从“David and Michael Reilley”中搜索“Java Network Programming and Distributed Computing”一书。您将能够找到从第 278 页开始的 RMI CALLBACK 实现的一个很好的示例!

作者定义了一种理解它的好方法,所以我认为复制/粘贴比尝试自己制作更好,这里是:

  • “理解回调的最简单方法是想一通电话。假设您想知道股票价格是否达到某个水平,并要求您的经纪人在达到某个水平时回电。当经纪人(事件)注意到股票价格反映了你的参数,他或她给你回电,通知你新的价格。那是一个回调。”

在默认实现中,RMI 只允许 CLIENT 与 SERVER 之间的通信,请求服务器主机中远程服务(远程对象)的操作。您可以使用回调方法而不是让您的服务器与您的客户端对话!

太好了!想象一下,如果您有一台服务器,您想检查它是否在线(或者如果没有删除/关闭)客户端!您必须请求持续使用一个远程对象,该对象应该返回一些布尔值(例如),告诉您这实际上是在线的。

那将是可怕的!因为你会失去一些网络带宽,所以一次又一次地请求服务器,一次又一次……导致一些连接池!

那应该很有用,在这些情况下使用 CALLBACK ;-)

我希望您能通过我的回答稍微了解回调是/做什么。

此致,

于 2012-09-05T19:26:05.420 回答