完整报错:
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())

测试一下,应该是可以的

问题解析

查阅后发现问题原因:

  1. hbase未开启thrift服务
  2. happybase的thrift服务与已开启的不匹配

而目前happybase只支持thrift的1代,不支持2代,所以要确保hbase开启了thrift

同时,使用docker安装的Hbase会自动开启thrift,但是源码安装的Hbase需要手动开启

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐