【HappyBase】连接hbase报错:ecybin.ProtocolError: No protocol version header

问题

使用以下代码访问 hbase 时出现错误: ecybin.ProtocolError: No protocol version header

def test_hbase():
    import happybase

    # 通过size控制连接池中的连接数量
    # pool = happybase.ConnectionPool(size=3, host="192.168.1.2", port=9090, protocol='compact', transport='framed')
    pool = happybase.ConnectionPool(size=3, host="192.168.1.2", port=9090)
    # 从连接池中取出一个连接
    with pool.connection() as conn:
        print(conn.tables())
    print("success")

if __name__ == '__main__':
    test_hbase()

解决

在 hbase-site.xml 中更改了一些设置后,它现在可以工作了!!我删除了以下属性:

<property>
  <name>hbase.regionserver.thrift.http</name>
  <value>true</value>
</property>
<property>
  <name>hbase.thrift.support.proxyuser</name>
  <value>true/value>
</property>

这两个选项,但是经过实际测试,开启这两个选项不仅会让 hue 无法连接上去,就连 happybase 也会报错。所以关闭了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值