• python利用thrift连接hive


    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")  
  • 相关阅读:
    Dos常用命令收集
    build.xml
    ActionScript. 3.0著名开源库 大集合
    知识:ASP.NET ViewState
    分享:JavaScript表格排序控制
    分享:ViewState压缩方法
    分享:获取Castle.ActiveRecord中的Nhibernate Session
    分享:ASP.NET避免VIEWSTATE过大
    分享:扩展Include关联查询
    积累:收集常用sql
  • 原文地址:https://www.cnblogs.com/lexus/p/2696957.html
Copyright © 2020-2023  润新知