Thrift官方提供的python库,对Python2.7支持很好,虽然Python3.x以上也可以安装,而且程序编写也没什么问题,但一旦和其他语言的服务端或者客户端联调时,就会出现各种各样莫名其妙的异常错误(同样代码,Python2.7没有问题),导致工作没法进行下去,耽误了不少时间。
在网上查了不少资料,发现相关信息很少,通过整理总结,这些问题主要还是Python3.x相对Python2.7没有做到语法兼容造成的,想解决,必须修改Thrift库的源码!
问题主要集中在两块:
1. Python3.x对Unicode的支持和新增的byte字节类
2. Python3.x取消UnboundMethodType类型
针对以上两类问题,需要修改三处代码:
1. transport/TTransport.py文件
Line 20:
from io import StringIO
改成
from io import BytesIO as StringIO
Line 56:
buff =''
改成
buff =b''
Line 143:
self.__rbuf = StringIO("")
改成
self.__rbuf = StringIO(b"")
2. protocol/TBinaryProtocol.py
Line 122-123:
self.writeI32(len(str))
self.trans.write(str)
改成
buff = bytes(str,'utf-8')
self.writeI32(len(buff))
self.trans.write(buff)
Line 223:
str = self.trans.readAll(len)
改成
len = self.readI32()
str = self.trans.readAll(len).decode('utf-8')
3. protocol\TProtocolDecorator.py
Line 31:
if type(member) in [MethodType, UnboundMethod, TypeFunctionType, LambdaType, BuiltinFunctionType, BuiltinMethodType]:
改成(去掉UnboundMethod类型,该类型等同MethodType,且在Python3.x中已经废除)
if type(member) in [MethodType, TypeFunctionType, LambdaType, BuiltinFunctionType, BuiltinMethodType]:
我对thrift应用和了解还不太深,但经过以上3个文件的改动,目前我自己程序中涉及到的thrift的功能在Thrift3.x下都可以正常使用了。
写下此文给遇到类似困难的朋友一点帮助。以上改动基于Python3.5下最新的thrift 0.9.3库改写,如其他版本有问题,欢迎留言讨论。