浙江省高等学校教师教育理论培训

微信搜索“毛凌志岗前心得”小程序

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

python利用thrift连接hive - 东杰书屋 - 博客频道 - CSDN.NET

python利用thrift连接hive


分类:
python编程
hadoop+hive+hbase


211人阅读
评论(0)
收藏
举报

 

Thrift是一个跨语言服务部署框架,最初由Facebook于2007年开发,后于2008年进入Apache孵化器(Apache Incubator)。类似于SOAP,COM 和CORBA,Thrift通过定义一个中间定义语言和Thrift代码生成工具,生成指定语言的代码。

目前,Thrift支持C++,Java, Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, Smalltalk和OCaml的代码生成

1.   安装thrift依赖库

yum install automake libtool flex bison pkgconfig gcc-c++ boost-devel libevent-devel zlib-devel python-devel ruby-devel 

下载thrift:http://mirror.bjtu.edu.cn/apache//thrift/0.8.0/thrift-0.8.0.tar.gz

安装thrift

tar
-zxvf 
thrift-0.8.0.tar.gz

cd
 thrift-0.8.0


./configure
--with-boost=/usr/local


make &&
make install


我的hive使用的是cloudera cdn3u3版本,python版本为2.7

在使用Python连接hive之前需要将hive中的文件拷贝到python的sys.path中

cp -r $HIVE_PATH/lib/py /usr/local/lib/python2.7/site-packages

 

  1. #!/usr/bin/env python  
  2. import sys  
  3. from hive_service import ThriftHive  
  4. from hive_service.ttypes import HiveServerException  
  5. from thrift import Thrift  
  6. from thrift.transport import TSocket  
  7. from thrift.transport import TTransport  
  8. from thrift.protocol import TBinaryProtocol  
  9.   
  10. def hiveExe(sql):  
  11.   
  12.     try:  
  13.         transport = TSocket.TSocket('127.0.0.1', 10000)   
  14.         transport = TTransport.TBufferedTransport(transport)  
  15.         protocol = TBinaryProtocol.TBinaryProtocol(transport)  
  16.         client = ThriftHive.Client(protocol)  
  17.         transport.open()  
  18.   
  19.   
  20.         client.execute(sql)  
  21.   
  22.         print "The return value is : "   
  23.         print client.fetchAll()  
  24.         print "............"  
  25.         transport.close()  
  26.     except Thrift.TException, tx:  
  27.         print '%s' % (tx.message)  
  28.   
  29. if __name__ == '__main__':  
  30.     hiveExe("select * from t_afan_test")  
posted on 2012-09-21 15:26  lexus  阅读(761)  评论(0编辑  收藏  举报