thrift TBinaryProtocol 数据传输格式

2024-05-05 00:18

本文主要是介绍thrift TBinaryProtocol 数据传输格式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Thrift version 0.9.0

服务端接收和发送数据

接收数据格式

方法数据格式

sz, = unpack('!i', socket.recv(4))
if sz < 0:version = sz & -65536 #版本掩码if version != -2147418112:raisetype = sz & 0x000000ff#字符串先读取一个INT(4字节)为字符串长度len, = unpack('!i', socket.recv(4))method = socket.recv(len)#读取长度为len的字符串为方法名seqid, = unpack('!i', socket.recv(4)) #读取一个INT(4字节)为序号

|——4byte—–|——4byte——|—-method len byte—- |—-4byte—-|
|-version/type—|–method len –|—method name ——–|—-seqid—-|

参数数据格式

.......
while True:ftype, = unpack('!b', socket.recv(1))if ftype == 0:raisefid, = unpack('!h', socket.recv(2))if fid == 1:if ftype == 11:len, = unpack('!i', socket.recv(4))input = socket.recv(len) #读取的参数.......

while:
|—–1byte—-|–2byte–|——4byte—— |–argument len byte–|
|—–ftype—-|—-fid—-|–argument len -|——argument ——-|

返回数据格式

D = StringIO()
D.write(pack("!i", (-2147418112| 2)))  #版本
D.write(pack("!i", len(method)))      #请求的方法名字长度
D.write(method)                     #请求的方法
D.write(pack("!i", seqid))          #请求的序号
D.write(pack("!b", 11))             #返回参数的类型 TType 11为字符串
D.write(pack("!h", 0))              #id 
D.write(pack("!i", len("2 from server 1024")))  #返回字符串的长度
D.write("2 from server 1024")       #返回字符串
D.write(pack("!b", 0))              #结束

|–4byte-|———–4byte——-|–method len byte– |—-4byte—-|——-4byte—–|-2byte-|–4byte–|–len byte–|-1byte-|
|—版本–|–请求的方法名字长度-|——请求的方法 —–|-请求的序号-|–返回参数的类型-|—id—|-返回字符串的长度-|-返回字符串-|-结束-|

这篇关于thrift TBinaryProtocol 数据传输格式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960413

相关文章

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

[数据集][目标检测]血细胞检测数据集VOC+YOLO格式2757张4类别

数据集格式:Pascal VOC格式+YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2757 标注数量(xml文件个数):2757 标注数量(txt文件个数):2757 标注类别数:4 标注类别名称:["Platelets","RBC","WBC","sickle cell"] 每个类别标注的框数:

一步一步将PlantUML类图导出为自定义格式的XMI文件

一步一步将PlantUML类图导出为自定义格式的XMI文件 说明: 首次发表日期:2024-09-08PlantUML官网: https://plantuml.com/zh/PlantUML命令行文档: https://plantuml.com/zh/command-line#6a26f548831e6a8cPlantUML XMI文档: https://plantuml.com/zh/xmi

单精度浮点数按存储格式转为整数的程序

///#include<cstdio>//-----------------union int_char{unsigned char ch[4];float i;};void out_put(union int_char x)//x86是小端对其模式,即最数据的最低位存储在地址的最低位上。{printf("单精度浮点数值为:%f\n",x.i,x.i);printf("存储位置从左到右

[数据集][目标检测]智慧农业草莓叶子病虫害检测数据集VOC+YOLO格式4040张9类别

数据集格式:Pascal VOC格式+YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):4040 标注数量(xml文件个数):4040 标注数量(txt文件个数):4040 标注类别数:9 标注类别名称:["acalcerosis","fertilizer","flower","fruit","grey

spring事务属性的xml格式配置

实际是使用代理做的事务优化 <!--配置事务的属性--><tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <!--匹配所有以add开头的方法--><tx:method name="add*" propagation="REQUIRED" /> <tx:metho

ORA-01861:文字与格式字符串不匹配

select t.*, t.rowid from log_jk_dtl t; insert into log_jk_dtl (rq,zy,kssj,jssj,memo)  values (to_date(sysdate,'yyyy-mm-dd'),'插入供应商', to_char(sysdate,'hh24:mi:ss'),to_char(sysdate,'hh24:mi:ss'),'备注'

ubuntu 和windows用samba服务器实现数据传输

1,linux安装samba服务器 sudo apt-get install samba samba-common 2,linux 配置权限,修改目录权限,linux下共享的文件权限设置。 sudo chmod 777 /home/lark -R 3. 添加samba用户  sudo smbpasswd -a  lark 4,配置共享目录 打开/smb.conf 在

Matplotlib图像读取和输出及jpg、png格式对比,及透明通道alpha设置

图像像素值 图像像素值一般size为3,也就是通道数,分别代表R,G,B,如果只有单一 一个值则表示灰度值,也就是说一张二维图片,当长和宽都为1080时,那么若是灰度图像,图像尺寸为(1080,1080,1)若是RGB图像则为(1080,1080,3), jpg、png图像格式 jpg图像的灰度值范围和RGB范围为[0,255],数值类型为uint8,也就是无符号整数 png图像的灰度值范