Асинхронный запрос с Thrift в Java - PullRequest
10 голосов
/ 19 сентября 2011

Я ищу пример того, как сделать асинхронный запрос в Java с помощью Thrift. Глядя на сгенерированный код, это кажется возможным, но я не могу найти ни одного примера того, как это сделать.

Вот пример сгенерированного кода, который предполагает существование асинхронного интерфейса:

...
AsyncIface {
    public static class Factory implements org.apache.thrift.async.TAsyncClientFactory<AsyncClient> {
      private org.apache.thrift.async.TAsyncClientManager clientManager;
      private org.apache.thrift.protocol.TProtocolFactory protocolFactory;
      public Factory(org.apache.thrift.async.TAsyncClientManager clientManager, org.apache.thrift.protocol.TProtocolFactory protocolFactory) {
        this.clientManager = clientManager;
        this.protocolFactory = protocolFactory;
      }
      public AsyncClient getAsyncClient(org.apache.thrift.transport.TNonblockingTransport transport) {
        return new AsyncClient(protocolFactory, clientManager, transport);
      }
    }
 ...

Любой указатель на то, как его использовать?

Ответы [ 2 ]

9 голосов
/ 10 января 2012

Используйте приведенный выше интерфейс, чтобы сделать асинхронный вызов следующим образом (в коде упоминается Cassandra, но он легко обобщается для вашего приложения):

TNonblockingTransport transport = new TNonblockingSocket("127.0.0.1", 9160);
TAsyncClientManager clientManager = new TAsyncClientManager();
TProtocolFactory protocolFactory = new TBinaryProtocol.Factory();
Cassandra.AsyncClient client = new Cassandra.AsyncClient(protocolFactory, clientManager, transport);

Cassandra.method_call(parameters, new Callback());
1 голос
/ 19 сентября 2011

У вас нет контекста, поэтому я дам вам основные части, которые вам понадобятся:

  • Чтобы выполнить асинхронный вызов, вам нужно сделать это в потоке
  • Чтобы получить результат, вам понадобится перезвонить

Ниже приведен основной пример этих элементов в игре:

final MyClient client;  // Who will get a call back to the their sendResult() method when asynch call finished
ExecutorService executor = Executors.newSingleThreadExecutor(); // Handy way to run code in a thread
Runnable task = new Runnable() { 
    public void run() { // Where the "do the call" code sits
        int result = someService.call(someParamter);
        client.sendResult(result); // For example, expecting an int result
    }
};
executor.submit(task); // This scheduled the runnable to be run
...