java执行hive语句,我如何在Java中对Hive进行异步调用?

I would like to execute a Hive query on the server in an asynchronous manner. The Hive query will likely take a long time to complete, so I would prefer not to block on the call. I am currently using Thirft to make a blocking call (blocks on client.execute()), but I have not seen an example of how to make a non-blocking call. Here is the blocking code:

TSocket transport = new TSocket("hive.example.com", 10000);

transport.setTimeout(999999999);

TBinaryProtocol protocol = new TBinaryProtocol(transport);

Client client = new ThriftHive.Client(protocol);

transport.open();

client.execute(hql); // Omitted HQL

List rows;

while ((rows = client.fetchN(1000)) != null) {

for (String row : rows) {

// Do stuff with row

}

}

transport.close();

The code above is missing try/catch blocks to keep it short.

Does anyone have any ideas how to do an async call? Can Hive/Thrift support it? Is there a better way?

Thanks!

解决方案

After talking to the Hive mailing list, Hive does not support async calls using Thirft.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值