当前位置: 首页 > 工具软件 > ThriftPy > 使用案例 >

解决python使用happybase连接hbase报错thriftpy2.transport.base.TTransportException....TSocket read 0 bytes

邬友樵
2023-12-01

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

 类似资料: