完整报错:
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需要手动开启



