RabbitMQ消息队列的小伙伴(八): ProtoBuf(Google Protocol Buffer)
来源:互联网 发布:成都关键词优化公司 编辑:程序博客网 时间:2024/05/18 01:44
什么是ProtoBuf?
一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。它很适合做数据存储或 RPC 数据交换格式。可用于通讯协议、数据存储等领域的语言无关、平台无关、可扩展的序列化结构数据格式。目前提供了 C++、Java、Python 三种语言的 API。
它可以作为RabbitMQ的Message的数据格式进行传输,由于是结构化的数据,这样就极大的方便了Consumer的数据高效处理。当然了你可能说使用XML不也可以吗?与XML相比,ProtoBuf有以下优势:
- 简单
- size小了3-10倍
- 速度快乐20-100倍
- 易于编程
- 减小了语义的歧义
当然了,的确还有很多类似的技术,比如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
0 0
- RabbitMQ消息队列的小伙伴(八): ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴(八): ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)(转)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- RabbitMQ消息队列的小伙伴: ProtoBuf(Google Protocol Buffer)
- Protobuf(google protocol buffer)
- ProtoBuf开发者指南大全(Google Protocol Buffer协议)
- protobuf - Google Protocol Buffer 的使用和原理
- [protobuf] Google Protocol Buffer 的使用和原理
- 【小松教你手游开发】【unity实用技能】Google Protocol Buffer(protobuf) 使用和研究
- RabbitMQ(消息队列)
- Google Protocol Buffer 的使用和原理(转载)
- Adapter,ListView的应用
- 人脸识别算法-特征脸方法(Eigenface)及python实现
- RabbitMQ消息队列(六):使用主题进行消息分发
- Java语言描述:动态规划法之编辑距离问题
- RabbitMQ消息队列(七):适用于云计算集群的远程调用(RPC)
- RabbitMQ消息队列的小伙伴(八): ProtoBuf(Google Protocol Buffer)
- Java 关于容器集合等数据结构详情图解,一目了然
- android.view.WindowManager$BadTokenException: Unable to add window -- token null is not valid
- IRAF处理文件整理器,搞定上线!!!
- RabbitMQ消息队列(九):Publisher的消息确认机制
- linux:用户和组文件解释(/etc/passwd、/etc/shadow、/etc/group、/etc/gshadow)
- cron表达式详解
- spring整合消息队列rabbitmq
- gpio_direction_output 和 gpio_set_value用法的区别