TAF(Total Application Framework) 基础通信协议 Tars协议
数据编码基本结构
每一个数据由两个部分组成,如下图:
| 头信息 | 实际数据 |
而其中头信息包括以下几个部分:
| 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协议相关推荐
- TAF(Total Application Framework) 基础通信协议 Tars语言
接口文件 Tars语言是一种类c++标识符的语言,用于生成具体的服务接口文件 Tars文件是Tars框架中客户端和服务端的通信接口,通过Tars的映射实现远程对象调用 Tars文件的扩展名必须以.ta ...
- TAF(Total Application Framework) TarsCPP
创建服务 /usr/local/tars/cpp/script/cmake_tars_server.sh MyApp HelloServer Hello 命令执行后,会在当前目录的TestApp/He ...
- Java Media Framework 基础教程
Java Media Framework 基础教程 作者:Eric Olson 来源:ibm 摘要: 很少发现有关于jmf方面的中文资料,这是在IBM上面找的一本书,可作为jmf的入门学习,业 ...
- Spring - Java/J2EE Application Framework 应用框架
Spring - Java/J2EE Application Framework Spring Framework 开发参考手册 Spring 中文论坛 Version 1.1 Spring 参考手册 ...
- JavaWeb第五讲 Web核心基础之HTTP协议
Web核心基础之HTTP协议 HTTP简介 对客户端和服务器端之间数据传输的格式规范,格式简称为"超文本传输协议".HTTP是一个基于TCP/IP通信协议来传递数据(HTML 文件 ...
- Java基础之Http协议的理解与总结
引言 HTTP是一个属于应用层的面向对象的协议,由于其简捷.快速的方式,适用于分布式超媒体信息系统.它于1990年提出,经过几年的使用与发展,得到不断地完善和扩展.目前在WWW中使用的是HTTP/1. ...
- 【AGL】初探AGL之Application framework
AGL – Application framework 1. 介绍 1.1 概述 下图通过应用程序安装场景描述了framework的主要组件以及其交互( 图片转载自: https://docs.aut ...
- 网络基础 之SSL协议
网络基础 之SSL协议 一.SSL 协议简介 SSL 的功能 SSL 的特性 SSL 在协议栈的位置 SSL 体系结构 二.SSL 协议工作原理 SSL协议可分为两层 SSL 的两个重要概念 SSL握 ...
- 第二章网页前端基础与HTTP协议
第二章 网页前端基础与HTTP协议 爬虫需要遵循网络传输协议才能与服务器进行通信,当与服务器建立通信后,爬虫才能获取网页内容,从而获取想要爬取的内容.获取到的网页内容通常为HTML(HyperText ...
最新文章
- 精心推荐10个高质量的网站,打开新世界的大门
- 修改完 字符串单词首字母大写
- 央行:货币政策稳健并不意味着一成不变
- Linux进程-进程的创建
- “埋点”到底要不要?
- 用Kotlin开发android平台语音识别,语义理解应用(olamisdk)
- apache httpclient 工具类_HttpClient
- sharepoint 2010 彻底删除用户
- 与0xf2值相等的是python_腾讯笔试题涵盖的基础知识
- python中编函数_在python中编写函数
- 判断radio单选框是否选中
- python 作用域从大到小排序_Python 内置函数、作用域、闭包、递归
- idea IDE 常用快捷键记录
- 如何让网页首屏更具视觉吸引力?
- python怎么背景实现循环_在Python的一段程序中如何使用多次事件循环详解
- ubuntu 20.04 安装可编辑截图工具 flameshot
- 分享程序员成长故事 解析IT职场困惑
- 一个例子搞懂单纯形法大M法和两阶段法
- 那一年,程维去洗脚城打工,王兴第十次创业失败,张一鸣第五次换工作……...
- 建立保持时间及违例解决方法
热门文章
- AngularJS 0005:作用域
- Struts DynaActionForm配置
- 冯诺依曼体系下 计算机主机不包括,2.冯·诺依曼理论体系下的计算机硬件组成包括.doc...
- 时尚衣裙外贸独立站搭建(一)
- 清理easyexcel导出07版Excel时产生的poi-sxssf-sheet*.xml临时文件
- linux服务--nfs服务
- iOS开发中touchesBegan和touchesEn…
- thinkpadE485做java_ThinkPad E485笔记本安装win10系统操作教程
- 实验5-三种基本结构综合应用:7-1 数字金字塔 (20 分)
- jQuery UI 设计主题