前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >重磅!腾讯与科大讯飞技术共创,Google ProtoBuf进入TARS家族!

重磅!腾讯与科大讯飞技术共创,Google ProtoBuf进入TARS家族!

原创
作者头像
腾讯开源
发布2018-01-15 18:34:44
1.6K0
发布2018-01-15 18:34:44
举报

引言:TARS框架及自有TARS协议在腾讯内部始于2007年。Google Protocol Buffers于2008年7月对外公布。随着微服务架构的发展及ProtoBuf的优异表现,目前在互联网上有着大量应用。此次腾讯与科大讯飞进行深度技术合作,将ProtoBuf与TARS自身的编解码协议进行集成,并于今天将TARS-PB正式对外开源!

(TARS-PB发布)

视频内容

protocol buffer

protocol buffer(简称PB)是google 的一种数据交换的格式,它独立于语言,独立于平台。google 提供了多种语言的实现:java、c#、c++、go 和 python,每一种实现都包含了相应语言的编译器以及库文件。由于它是一种二进制的格式,比使用 xml 进行数据交换快许多。可以把它用于分布式应用之间的数据通信或者异构环境下的数据交换。作为一种效率和兼容性都很优秀的二进制数据传输格式,可以用于诸如网络传输、配置文件、数据存储等诸多领域。

正因为PB有着如此优异的表现,目前PB在移动互联网行业有着大量的应用。在Tars-PB发布之后,已经使用PB作为内部数据交换协议的用户可以更方便地对Tars进行集成。

Tars-PB解决方案

下图是Tars的服务端与客户端的实现架构图:

通过对Tars ServantImp和ServantProxy的扩展,以及增加相应的protobuf codec实现了PB对Tars的支持。

对象生成

为了减少对PB序列化和反序列化的侵入,对对象仍然采用PB原生的生成方式。

Service生成

接口代码的生成为了保持tars的整体风格按照tars的方式进行生成。

Protoc插件

protoc官方提供了插件机制,只要满足相关的插件规范,用户可以自定义开发自已的插件。protoc在生成代码的时候,可以调用用户自定义实现的插件,从而生成用户自定义的代码。

我们就是利用protoc的插件机制,来实现 tars-pb 代码的生成。

使用方法

  • 编写PB文件 编写一个proto描述文件:
代码语言:js
复制
message HelloRequest {
    required string greeting = 1;
}
message HelloReply {
    required string reply = 1;
}
service Greeter {
    rpc SayHello (HelloRequest) returns (HelloReply) {}
}protoc ‐‐plugin=protoc-gen-tars-java=${plugin_path} 
--tars-java_out=${out_path} 
--java_out=${out_path} ${proto_path}
  • 生成代码 执行命令,通过PB官方插件和Tars插件生成代码:
  • 编写业务实现 后续的步骤与正常的tars使用相同,不在赘述。

使用pb作为编解码协议,经过测试,没有增加额外的性能损耗。测试数据将会在Tars开源社区公布。

若您在使用Tars-PB时或者对Tars本身有任何意见和建议,欢迎访问:

https://github.com/Tencent/Tars

原文来自:腾讯开源 公众号

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • protocol buffer
  • Tars-PB解决方案
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档