Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/hskj/anaconda3/lib/python3.5/site-packages/happybase/connection.py", line 242, in tables
names = self.client.getTableNames()
File "/hskj/anaconda3/lib/python3.5/site-packages/thriftpy/thrift.py", line 198, in _req
return self._recv(_api)
File "/hskj/anaconda3/lib/python3.5/site-packages/thriftpy/thrift.py", line 210, in _recv
fname, mtype, rseqid = self._iprot.read_message_begin()
File "thriftpy/protocol/cybin/cybin.pyx", line 439, in cybin.TCyBinaryProtocol.read_message_begin (thriftpy/protocol/cybin/cybin.c:6470)
cybin.ProtocolError: No protocol version header
问问题
1784 次
1 回答
0
该问题似乎与“严格读/写”标志的使用有关。标准 Thrift 二进制协议有一个非标准的“cybin”实现,错误出现在这个特定的代码块中:
def read_message_begin(self):
cdef int32_t size, version, seqid
cdef TType ttype
size = read_i32(self.trans)
if size < 0:
version = size & VERSION_MASK
if version != VERSION_1:
raise ProtocolError('invalid version %d' % version)
name = c_read_val(self.trans, T_STRING)
ttype = <TType>(size & TYPE_MASK)
else:
if self.strict_read:
raise ProtocolError('No protocol version header') // <<<<<<
name = c_read_string(self.trans, size)
ttype = <TType>(read_i08(self.trans))
seqid = read_i32(self.trans)
return name, ttype, seqid
在没有尝试过的情况下,我猜想在实例化 CyBin 协议时将“严格读取”标志设置为 false(而不是 true)应该可以解决问题。
于 2017-04-30T11:34:49.810 回答