我能够使用Drill分别查询hive,hbase。现在,我正在尝试查询hive中的HbaseStorageHandler类型表。为此,我在Hive Storage Plugin中将这些属性添加为
{
"type": "hive",
"enabled": true,
"configProps": {
"hive.metastore.uris": "thrift://trinitybdClusterM02.trinitymobility.local:9083",
"javax.jdo.option.ConnectionURL": "jdbc:mysql://localhost:3306/metastore?createDatabaseIfNotExist=true",
"hive.metastore.warehouse.dir": "/tmp/drill_hive_wh",
"fs.default.name": "hdfs://trinitybdClusterM02.trinitymobility.local:9000",
"hive.metastore.sasl.enabled": "false",
"hbase.zookeeper.quorum": "localhost",
"hbase.zookeeper.property.clientPort": "2181"
}
}
我试图查询,
0:jdbc:drill:zk = localhost>使用hive.test;
0:jdbc:drill:zk = localhost>从twitter_test_nlp限制1中选择*;
它给出错误,因为
Error: SYSTEM ERROR: NoSuchMethodError: org.apache.hadoop.hbase.client.Scan.setAttribute(Ljava/lang/String;[B)V
Fragment 0:0
[Error Id: fc3994f4-7d7e-475e-870b-259ac91ea81a on trinitybdClusterM02.trinitymobility.local:31010] (state=,code=0)
任何人都在使用此类型,请与我分享为查询Hive的HBaseStorageHandler表必须添加的属性。
最佳答案
在演习1.9中,此问题已解决。 Drill 1.9还直接通过Hive Storage插件支持HbaseStorageHandler表(Hive和hbase集成表),并且直接支持空间查询(例如st_contains()等),因此如果有人需要这些类型的需求,请使用Drill 1.9.0。
关于hadoop - Drill中的HbaseStorageHandler插件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40585228/