常用的跨语言通信方案

本文介绍了三种流行的跨语言通信方案:Google protobuf、Apache Thrift 和 Apache Avro。protobuf 以其高性能和简单易用受到青睐,但语言支持有限且不具自描述性;Thrift 支持多种语言,提供完整的RPC堆栈,但也缺少动态特性;Avro 则拥有自描述消息和动态消息支持,但仅支持Avro序列化格式。
摘要由CSDN通过智能技术生成
传统的跨语言通信方案:
基于SOAP消息格式的WebService
基于JSON消息格式的RESTful 服务
主要弊端:
XML体积太大,解析性能极差
JSON体积相对较小,解析相对较快,但表达能力较弱
现在比较流行的跨语言通信方案:
Google protobuf (http://code.google.com/p/protobuf)
Apache Thrift (http://thrift.apache.org/)
Apache Avro ( http://avro.apache.org/)


Google protobuf:
优点
二进制消息,性能好/效率高(空间和时间效率都很不错)
proto文件生成目标代码,简单易用
序列化反序列化直接对应程序中的数据类,不需要解析后在进行映射(XML,JSON都是这种方式)
支持向前兼容(新加字段采用默认值)和向后兼容(忽略新加字段),简化升级
支持多种语言
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值