Thrift(三):异步客户端构建

  • Thrift 为客户端提供了非阻塞的调用方式,使用 TAsyncClientManager 管理客户端的请求,并提供一个 AsyncMethodCallback 接口实现用于处理调用结果,并实现下面两个方法:
    • onComplete:处理服务返回的结果值
    • onError:处理调用服务过程中出现的异常
  • 下面是客户端异步调用代码例子
public class Client {
    public static void main(String[] args) throws Exception {
        // 异步调用管理器
        TAsyncClientManager clientManager = new TAsyncClientManager();
        // 客户端应该使用非阻塞 IO
        TNonblockingTransport transport = new TNonblockingSocket("localhost",8181);
        // 协议与服务端需要一致
        TProtocolFactory tProtocolFactory = new TBinaryProtocol.Factory();
        // 异步调用
        UserService.AsyncClient asyncClient = new UserService.AsyncClient(tProtocolFactory,clientManager,transport);
        asyncClient.getUser(123, new AsyncMethodCallback() {
            // 处理服务返回的结果值
            public void onComplete(User user) {
                System.out.println(user);
            }

            // 处理调用服务过程中出现的异常
            public void onError(Exception e) {

            }
        });
        // 让线程等待一秒,以免主线程先于异步调用结果之前结束,导致结果未被输出
        TimeUnit.SECONDS.sleep(1);
    }
}

你可能感兴趣的:(Thrift(三):异步客户端构建)