【问题标题】:Cannot create simple table using Happybase in Python无法在 Python 中使用 Happybase 创建简单表
【发布时间】:2019-08-12 23:52:09
【问题描述】:

我正在尝试使用 Happybase 创建一个表。首先,我输入以下命令让 Hbase 和 Thrift 运行:

start-hbase.sh
hbase thrift start &

一旦运行,我打开 Python 的命令提示符并输入以下内容:

import happybase as hb
connection = hb.Connection()
connection.open()

但是当我尝试创建表格时:

connection.create_table(
'mytable',
{'cf1': dict(max_versions=10),
 'cf2': dict(max_versions=1, block_cache_enabled=False),
 'cf3': dict(),  # use defaults
}

我收到以下我不明白的错误。

Traceback (most recent call last):
  File "<stdin>", line 5, in <module>
  File "/usr/local/lib/python2.7/dist-packages/happybase/connection.py", line 309, in create_table
    self.client.createTable(name, column_descriptors)
  File "/usr/local/lib/python2.7/dist-packages/thriftpy/thrift.py", line 198, in _req
    return self._recv(_api)
  File "/usr/local/lib/python2.7/dist-packages/thriftpy/thrift.py", line 210, in _recv
    fname, mtype, rseqid = self._iprot.read_message_begin()
  File "thriftpy/protocol/cybin/cybin.pyx", line 429, in cybin.TCyBinaryProtocol.read_message_begin (thriftpy/protocol/cybin/cybin.c:6325)
  File "thriftpy/protocol/cybin/cybin.pyx", line 60, in cybin.read_i32 (thriftpy/protocol/cybin/cybin.c:1546)
  File "thriftpy/transport/buffered/cybuffered.pyx", line 65, in thriftpy.transport.buffered.cybuffered.TCyBufferedTransport.c_read (thriftpy/transport/buffered/cybuffered.c:1881)
  File "thriftpy/transport/buffered/cybuffered.pyx", line 69, in thriftpy.transport.buffered.cybuffered.TCyBufferedTransport.read_trans (thriftpy/transport/buffered/cybuffered.c:1948)
  File "thriftpy/transport/cybase.pyx", line 61, in thriftpy.transport.cybase.TCyBuffer.read_trans (thriftpy/transport/cybase.c:1472)
  File "/usr/local/lib/python2.7/dist-packages/thriftpy/transport/socket.py", line 125, in read
    message='TSocket read 0 bytes')
thriftpy.transport.TTransportException: TTransportException(message='TSocket read 0 bytes', type=4)
)

【问题讨论】:

    标签: python hadoop hbase thrift happybase


    【解决方案1】:

    您需要指定服务器地址,可能还有端口:

    connection = hb.Connection(SERVER, PORT)
    

    您可以省略端口值,因为默认值很可能会匹配,但以防万一检查您的 thrift 服务器正在侦听的端口并将其指定为数值

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2020-06-28
      • 2019-01-18
      • 1970-01-01
      • 2021-07-16
      • 2014-06-06
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多