【发布时间】:2017-02-21 14:33:07
【问题描述】:
我想使用 JAVA 通过 Spark 访问 HBase。除了this 之外,我还没有找到任何示例。答案里写着,
你也可以用 Java 写这个
我从How to read from hbase using spark复制了这段代码:
import org.apache.hadoop.hbase.client.{HBaseAdmin, Result}
import org.apache.hadoop.hbase.{ HBaseConfiguration, HTableDescriptor }
import org.apache.hadoop.hbase.mapreduce.TableInputFormat
import org.apache.hadoop.hbase.io.ImmutableBytesWritable
import org.apache.spark._
object HBaseRead {
def main(args: Array[String]) {
val sparkConf = new SparkConf().setAppName("HBaseRead").setMaster("local[2]")
val sc = new SparkContext(sparkConf)
val conf = HBaseConfiguration.create()
val tableName = "table1"
System.setProperty("user.name", "hdfs")
System.setProperty("HADOOP_USER_NAME", "hdfs")
conf.set("hbase.master", "localhost:60000")
conf.setInt("timeout", 120000)
conf.set("hbase.zookeeper.quorum", "localhost")
conf.set("zookeeper.znode.parent", "/hbase-unsecure")
conf.set(TableInputFormat.INPUT_TABLE, tableName)
val admin = new HBaseAdmin(conf)
if (!admin.isTableAvailable(tableName)) {
val tableDesc = new HTableDescriptor(tableName)
admin.createTable(tableDesc)
}
val hBaseRDD = sc.newAPIHadoopRDD(conf, classOf[TableInputFormat], classOf[ImmutableBytesWritable], classOf[Result])
println("Number of Records found : " + hBaseRDD.count())
sc.stop()
}
}
谁能给我一些提示如何找到正确的依赖项、对象和东西?
似乎HBaseConfiguration 在hbase-client 中,但我实际上坚持使用TableInputFormat.INPUT_TABLE。这不应该在同一个依赖项中吗?
有没有更好的方法用 spark 访问 hbase?
【问题讨论】:
标签: java hadoop apache-spark hbase