我是靠谱客的博主 激动咖啡,最近开发中收集的这篇文章主要介绍python hbase 连接池_python 调用HBase 范例,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

python 调用HBase 实例

新来的一个工程师不懂HBase,java不熟,python还行,我建议他那可以考虑用HBase的thrift调用,完成目前的工作。

首先,安装thrift

下载thrift,这里,我用的是thrift-0.7.0-dev.tar.gz 这个版本

tar xzf thrift-0.7.0-dev.tar.gz

cd thrift-0.7.0-dev

sudo ./configure --with-cpp=no --with-ruby=no

sudo make

sudo make install

然后,到HBase的源码包里,找到

src/main/resources/org/apache/hadoop/hbase/thrift/

执行

thrift --gen py Hbase.thrift

mv gen-py/hbase/ /usr/lib/python2.4/site-packages/ (根据python版本可能有不同)

我这里写了些调用的脚本,供大家参考

from unittest import TestCase, main

from thrift import Thrift

from thrift.transport import TSocket

from thrift.transport import TTransport

from thrift.protocol import TBinaryProtocol

from hbase import Hbase

from hbase.ttypes import ColumnDescriptor, Mutation, BatchMutation

class HBaseTester:

def __init__(self, netloc, port, table="staftesttable"):

self.tableName = table

self.transport = TTransport.TBufferedTransport(

TSocket.TSocket(netloc, port))

self.protocol = TBinaryProtocol.TBinaryProtocol(self.transport)

self.client = Hbase.Client(self.protocol)

self.transport.open()

tables = self.client.getTableNames()

if self.tableName not in tables:

self.__createTable()

def __del__(self):

self.transport.close()

def __createTable(self):

name = ColumnDescriptor(name='name')

foo = ColumnDescriptor(name='foo')

self.client.createTable(self.tableName,

[name,foo])

def put(self,key,name,foo):

name = Mutation(column="name:v", value=name)

foo = Mutation(column="foo:v",value=foo)

self.client.mutateRow(self.tablename,key,[name,foo])

def scanner(self,column):

scanner = client.scannerOpen(self.tablename,"",[column])

r = client.scannerGet(scanner)

result= []

while r:

print r[0]

result.append(r[0])

r = client.scannerGet(scanner)

print "Scanner finished"

return result

class TestHBaseTester(TestCase):

def setUp(self):

self.writer = HBaseTester("localhost", 9090)

def tearDown(self):

name = self.writer.tableName

client = self.writer.client

client.disableTable(name)

client.deleteTable(name)

def testCreate(self):

tableName = self.writer.tableName

client = self.writer.client

self.assertTrue(self.writer.tableName in client.getTableNames())

columns =['name:','foo:']

for i in client.getColumnDescriptors(tableName):

self.assertTrue(i in columns)

def testPut(self):

self.writer.put("r1","n1","f1")

self.writer.put("r2","n2","f2")

self.writer.put("r3","n3","")

self.writer.scanner("name:")

if __name__ == "__main__":

main()

最后

以上就是激动咖啡为你收集整理的python hbase 连接池_python 调用HBase 范例的全部内容,希望文章能够帮你解决python hbase 连接池_python 调用HBase 范例所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(49)

评论列表共有 0 条评论

立即
投稿
返回
顶部