解决python使用happybase连接hbase报错thriftpy2.transport.base.TTransportException....TSocket read 0 bytes
完整报错:thriftpy2.transport.base.TTransportException: TTransportException(type=4, message='TSocket read 0 bytes')解决方法cd hbase-2.4.9/bin/ # 这里进入自己的bin目录下./hbase-daemon.sh start thrift注意:如果已经开启了thrift2,需要关
·
完整报错:
thriftpy2.transport.base.TTransportException: TTransportException(type=4, message='TSocket read 0 bytes')
解决方法
cd hbase-2.4.9/bin/ # 这里进入自己的bin目录下
./hbase-daemon.sh start thrift
注意:如果已经开启了thrift2
,需要关闭thrift2
,启用thrift
的1代,使用:
cd hbase-2.4.9/bin/
./hbase-daemon.sh stop thrift2
./hbase-daemon.sh start thrift
而happybase
使用:
import happybase
connection = happybase.Connection(host="127.0.0.1",port=9090)
print(connection.tables())
测试一下,应该是可以的
问题解析
查阅后发现问题原因:
- hbase未开启thrift服务
- happybase的thrift服务与已开启的不匹配
而目前happybase
只支持thrift
的1代,不支持2代,所以要确保hbase开启了thrift
同时,使用docker安装的Hbase
会自动开启thrift
,但是源码安装的Hbase
需要手动开启
更多推荐
所有评论(0)