开发者社区> anzhsoft> 正文
阿里云
为了无法计算的价值
打开APP
阿里云APP内打开

RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)

简介:
+关注继续查看

     什么是ProtoBuf?

     一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。目前提供了 C++、Java、Python 三种语言的 API。

     它可以作为RabbitMQ的Message的数据格式进行传输,由于是结构化的数据,这样就极大的方便了Consumer的数据高效处理。当然了你可能说使用XML不也可以吗?与XML相比,ProtoBuf有以下优势:

  1. 简单
  2. size小了3-10倍
  3. 速度快乐20-100倍
  4. 易于编程
  5. 减小了语义的歧义

       当然了,的确还有很多类似的技术,比如JSON,Thrift等等,和他们相比,ProtoBuf的优势或者劣势在哪里?简单说来,ProtoBuf就是简单,快。以测试为证:项目 thrift-protobuf-compare 比较了这些类似的技术,下图 显示了该项目的一项测试结果。

在占用空间上的性能比较:

由此可见,ProtoBuf具有速度和空间的优势,使得它现在应用非常广泛。比如Hadoop就使用了它。

更多信息,请阅 http://www.ibm.com/developerworks/cn/linux/l-cn-gpb/。


尊重原创,转载请注明出处 anzhsoft:http://blog.csdn.net/anzhsoft/article/details/19771671

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
Google Earth Engine ——LANDSAT 7烧伤面积指数(BAI)
Google Earth Engine ——LANDSAT 7烧伤面积指数(BAI)
26 0
Google Earth Engine(GEE)——环境监测和建模的必看论文推荐
Google Earth Engine(GEE)——环境监测和建模的必看论文推荐
41 0
Google Earth Engine(GEE)——Landsat8影像数组排序和归约
Google Earth Engine(GEE)——Landsat8影像数组排序和归约
46 0
Google Earth Engine ——LANDSAT8——RAW系列数据
Google Earth Engine ——LANDSAT8——RAW系列数据
53 0
google protobuf学习笔记一:windows下环境配置
Windows下google protobuf开发环境配置 最近项目需求,Client与Server的网络通信协议传输使用google protobuf rpc。对于Protobuf,以前是只知道有这个东西,知道它干嘛,而且一直很仰慕,但是从来没学习过,最近刚好趁着项目机会,好好学习学习。
2821 0
Google 是如何构建 web 框架的
本文讲的是Google 是如何构建 web 框架的,对于不在 Google 的众多开发者来说,这件事非常的令人吃惊和违背常理,但是这个代码仓库却工作的非常好。(上面链接里的文章提供了很好的例子,所以我在此不再赘述。)
1354 0
Google I/O Android官方新体系架构之:Lifecycle
Google I/O Android官方新体系架构之:Lifecycle Google官方在 I/O大会中引入一些列Android新的体系架构内容,其中有一个是Android的Lifecycle。
986 0
+关注
100
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
冬季实战营第三期:MySQL数据库进阶实战
立即下载