数据编码基本结构

每一个数据由两个部分组成,如下图:

| 头信息 | 实际数据 |

而其中头信息包括以下几个部分:

| Type(4 bits) | Tag 1(4 bits) | Tag 2(1 byte) |

Tag 2是可选的,当Tag的值不超过14时,只需要用Tag 1就可以表示;当Tag的值超过14而小于256时,Tag 1固定为15,而用Tag 2表示Tag的值。Tag不允许大于255。

Tag由Tag 1和Tag 2一起表示。取值范围是0~255,即该数据在结构中的字段ID,用来区分不同的字段。

Type表示类型,用4个二进制位表示,取值范围是0~15,用来标识该数据的类型。不同类型的数据,其后紧跟着的实际数据的长度和格式都是不一样的,详见一下的类型表。

基本类型(包括int1、int2、int4、int8、float、double)

头信息后紧跟数值数据。char、bool也被看作整型。所有的整型数据之间不做区分,也就是说一个short的值可以赋值给一个int。

数字0

头信息后不跟数据,表示数值0。所有基本类型的0值都可以这样来表示。

这是考虑到数字0出现的概率比较大,所以单独提一个类型,以节省空间。

字符串(包括String1、String4)

String1跟一个字节的长度(该长度数据不包括头信息),接着紧跟内容。

String4与之类似。

Map

紧跟一个整形数据(包括头信息)表示Map的大小,然后紧跟[Key数据(Tag为0),Value数据(Tag为1)]对列表。

List

紧跟一个整形数据(包括头信息)表示List的大小,然后紧跟元素列表(Tag为0)

自定义结构开始

自定义结构开始标志,后面紧跟字段数据,字段按照tag升序顺序排列

自定义结构结束

自定义结构结束标志,Tag为0

对象持久化

对于自定义结构的持久化,由开始标志与结束标志来标识。

比如如下结构定义:

struct TestInfo
{1  require  int    ii  = 34;2  optional string s   = "abc";
};
​
struct TestInfo2
{1  require TestInfo  t;2  require int       a = 12345;
}

其中,默认的TestInfo2结构编码后结果为:

消息格式

TUP底层协议完全采用Tars定义,与Tars的底层数据包定义一致,其中require的字段为TUP必须的字段,optional为访问Tars服务时额外需要用到的字段。

请求包:

//请求包体
struct RequestPacket
{1  require short        iVersion;         //版本号2  optional byte        cPacketType;      //包类型3  optional int         iMessageType;     //消息类型4  require int          iRequestId;       //请求ID5  require string       sServantName;     //servant名字6  require string       sFuncName;        //函数名称7  require vector<byte> sBuffer;          //二进制buffer8  optional int         iTimeout;         //超时时间(毫秒)9  optional map<string, string> context;  //业务上下文10 optional map<string, string> status;   //框架协议上下文
};

响应包:

//响应包体
struct ResponsePacket
{1 require short         iVersion;       //版本号2 optional byte         cPacketType;    //包类型3 require int           iRequestId;     //请求ID4 optional int          iMessageType;   //消息类型5 optional int          iRet;           //返回值6 require vector<byte>  sBuffer;        //二进制流7 optional map<string, string> status;  //协议上下文8 optional string       sResultDesc;    //结果描述
};
​
//返回值
const int TAFSERVERSUCCESS       = 0;       //服务器端处理成功
const int TAFSERVERDECODEERR     = -1;      //服务器端解码异常
const int TAFSERVERENCODEERR     = -2;      //服务器端编码异常
const int TAFSERVERNOFUNCERR     = -3;      //服务器端没有该函数
const int TAFSERVERNOSERVANTERR  = -4;      //服务器端没有该Servant对象
const int TAFSERVERRESETGRID     = -5;      //服务器端灰度状态不一致
const int TAFSERVERQUEUETIMEOUT  = -6;      //服务器队列超过限制
const int TAFASYNCCALLTIMEOUT    = -7;      //异步调用超时
const int TAFINVOKETIMEOUT       = -7;      //调用超时
const int TAFPROXYCONNECTERR     = -8;      //proxy链接异常
const int TAFSERVEROVERLOAD      = -9;      //服务器端超负载,超过队列长度
const int TAFADAPTERNULL         = -10;     //客户端选路为空,服务不存在或者所有服务down掉了
const int TAFINVOKEBYINVALIDESET = -11;     //客户端按set规则调用非法
const int TAFCLIENTDECODEERR     = -12;     //客户端解码异常
const int TAFSERVERUNKNOWNERR    = -99;     //服务器端位置异常

官方:
https://tarscloud.gitbook.io/tarsdocs/rumen/tars-protocol

TAF(Total Application Framework) 基础通信协议 Tars协议相关推荐

  1. TAF(Total Application Framework) 基础通信协议 Tars语言

    接口文件 Tars语言是一种类c++标识符的语言,用于生成具体的服务接口文件 Tars文件是Tars框架中客户端和服务端的通信接口,通过Tars的映射实现远程对象调用 Tars文件的扩展名必须以.ta ...

  2. TAF(Total Application Framework) TarsCPP

    创建服务 /usr/local/tars/cpp/script/cmake_tars_server.sh MyApp HelloServer Hello 命令执行后,会在当前目录的TestApp/He ...

  3. Java Media Framework 基础教程

    Java Media Framework 基础教程 作者:Eric Olson     来源:ibm 摘要: 很少发现有关于jmf方面的中文资料,这是在IBM上面找的一本书,可作为jmf的入门学习,业 ...

  4. Spring - Java/J2EE Application Framework 应用框架

    Spring - Java/J2EE Application Framework Spring Framework 开发参考手册 Spring 中文论坛 Version 1.1 Spring 参考手册 ...

  5. JavaWeb第五讲 Web核心基础之HTTP协议

    Web核心基础之HTTP协议 HTTP简介 对客户端和服务器端之间数据传输的格式规范,格式简称为"超文本传输协议".HTTP是一个基于TCP/IP通信协议来传递数据(HTML 文件 ...

  6. Java基础之Http协议的理解与总结

    引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...

  7. 【AGL】初探AGL之Application framework

    AGL – Application framework 1. 介绍 1.1 概述 下图通过应用程序安装场景描述了framework的主要组件以及其交互( 图片转载自: https://docs.aut ...

  8. 网络基础 之SSL协议

    网络基础 之SSL协议 一.SSL 协议简介 SSL 的功能 SSL 的特性 SSL 在协议栈的位置 SSL 体系结构 二.SSL 协议工作原理 SSL协议可分为两层 SSL 的两个重要概念 SSL握 ...

  9. 第二章网页前端基础与HTTP协议

    第二章 网页前端基础与HTTP协议 爬虫需要遵循网络传输协议才能与服务器进行通信,当与服务器建立通信后,爬虫才能获取网页内容,从而获取想要爬取的内容.获取到的网页内容通常为HTML(HyperText ...

最新文章

  1. 精心推荐10个高质量的网站,打开新世界的大门
  2. 修改完 字符串单词首字母大写
  3. 央行:货币政策稳健并不意味着一成不变
  4. Linux进程-进程的创建
  5. “埋点”到底要不要?
  6. 用Kotlin开发android平台语音识别,语义理解应用(olamisdk)
  7. apache httpclient 工具类_HttpClient
  8. sharepoint 2010 彻底删除用户
  9. 与0xf2值相等的是python_腾讯笔试题涵盖的基础知识
  10. python中编函数_在python中编写函数
  11. 判断radio单选框是否选中
  12. python 作用域从大到小排序_Python 内置函数、作用域、闭包、递归
  13. idea IDE 常用快捷键记录
  14. 如何让网页首屏更具视觉吸引力?
  15. python怎么背景实现循环_在Python的一段程序中如何使用多次事件循环详解
  16. ubuntu 20.04 安装可编辑截图工具 flameshot
  17. 分享程序员成长故事 解析IT职场困惑
  18. 一个例子搞懂单纯形法大M法和两阶段法
  19. 那一年,程维去洗脚城打工,王兴第十次创业失败,张一鸣第五次换工作……...
  20. 建立保持时间及违例解决方法

热门文章

  1. AngularJS 0005:作用域
  2. Struts DynaActionForm配置
  3. 冯诺依曼体系下 计算机主机不包括,2.冯·诺依曼理论体系下的计算机硬件组成包括.doc...
  4. 时尚衣裙外贸独立站搭建(一)
  5. 清理easyexcel导出07版Excel时产生的poi-sxssf-sheet*.xml临时文件
  6. linux服务--nfs服务
  7. iOS开发中touchesBegan和touchesEn…
  8. thinkpadE485做java_ThinkPad E485笔记本安装win10系统操作教程
  9. 实验5-三种基本结构综合应用:7-1 数字金字塔 (20 分)
  10. jQuery UI 设计主题