完整报错:
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())
测试一下,应该是可以的
查阅后发现问题原因:
而目前happybase
只支持thrift
的1代,不支持2代,所以要确保hbase开启了thrift
同时,使用docker安装的Hbase
会自动开启thrift
,但是源码安装的Hbase
需要手动开启