解析Tars协议(Node版本)

Tars(1)微服务之间的通信采用Tars协议完成,Tars协议是标准的 TLV 协议,该协议为每个字段定义了Tag值、Length值域长度和Value值域。

在Tars协议进行序列化的时候,内部会维护一个 Position 作为位置标记符。我们可以看到每次写入的时候该Position 都会增大,在写入前也会对已有内存空间大小进行分配。如果超出某个界限就会重新分配内存

具体实现如下:

由于Int8、Int16、Int32的长度都已知,所以不需要额外维护 TLV 中的 L ,但面对Map、List、String时则需要额外维护一个 Length 代表该 Tag.Value.Length

具体实现如下:

整个代码实现非常的工整清晰,用我的话说就是美。大家有兴趣可以Clone下来阅读。

当然,我也使用TS写了一个基本的实现,方便大家更好理解Tars协议内部是如何进行序列化的。

这是 写入二进制的父类

现在我们创建一个WriteStream的子类代表符合Tars协议规范的结构体,然后模拟序列化写入二进制数据。

这样子就相当于写入了4个不同大小的 Int 和一个 String ,然后再写进去了一个 MAP

我们重点讲一下 WriteMap函数

function objToStream 函数的作用是将 Map的包裹类 T_Map的实例对象 写成二进制数据。

写完后,会计算所占用的内存空间,然后将占用的存储空间写入先写入Buffer中。

最后将二进制数据写入已有的Buffer中。

至此,完成写入。

如何读呢?同样的可以先定义一个父类。

ReadMap的实现与WriteMap基本相同,先拿到ByteLength,再根据ByteLength和Position从缓冲区中取出一块二进制数据的进行处理。

然后我们对上述序列化后的数据进行反序列化。

最后执行下

至此,解析完毕!

参考资料:

(1)Tars : 早期名为TAF(Tencent Application Framework) ,是腾讯内部使用多年的微服务治理框架,在18年时开源后改名为Tars并捐赠给Linux基金会。

(2)TarsNode协议源码 github.com/tars-node/s...

(3)TS学习版本 github.com/chelizichen...__

相关推荐
砍材农夫8 分钟前
TCP和UDP区别
后端
千寻girling42 分钟前
一份不可多得的 《 Django 》 零基础入门教程
后端·python·面试
千寻girling1 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
贾铭1 小时前
如何实现一个网页版的剪映(三)使用fabric.js绘制时间轴
前端·后端
xiaoye20181 小时前
Spring 自定义 Redis 超时:TTL、TTI 与 Pipeline 实战
后端
程序员爱钓鱼4 小时前
GoHTML解析利器:github.com/PuerkitoBio/goquery实战指南
后端·google·go
golang学习记4 小时前
从“大泥球“到模块化单体:Spring Modulith + IntelliJ IDEA 拯救你的代码
后端·intellij idea
颜酱4 小时前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
离开地球表面_994 小时前
金三银四程序员跳槽指南:从简历到面试再到 Offer 的全流程准备
前端·后端·面试
UrbanJazzerati4 小时前
Scrapling入门指南:零基础也能学会的网页抓取神器
后端·面试