REST、SOAP、protocolbuf、thrift、avro

REST、SOAP、protocolbuf、thrift、avro

@(JAVA)[hbase, hadoop, storm]

为提供异构环境或者跨语言的通信,需要一个中间协议进行转换,常用的有2大类:

一是传统的明文协议,如REST/SOAP等,这类协议最常用的方式是通过XML/JSON方式进行数据交互,然后通过解释这些文件得到实际所需的数据。其优点是内容可读,缺点是需要在大量的冗余信息,如XML的头,标签等内容。这对于有大量交互的情况时,会浪费大量的带宽。

第二种是protocolbuf、thrift、avro等二进制RPC层。最早是google实现的protocol buffer,但由于google并未将之开源,因此后来facebook写了一套thrift。最后,hadoop项目的创建者Doug Cutting写了一套avro。它们的功能都类似,细节肯定有不同之处。

举个例子,用户如何通过python来访问hbase的基本原理:

  1. hbase启动一个thrift服务
  2. 客户端使用python的API对表进行访问
  3. 这个API会被转化为某种格式(如REST的JSON,或者thrift的二进制),并发送至thift服务器
  4. thrift服务器解释这个JSON文件(或者其它格式),然后转化为内部的API(如HTable)
  5. 通过hbase的内部实现(java)来访问真正的数据。

protocol buffer与thrift/avro的最大不同在于后者有自己的RPC实现,因此可以启动server,而protocol buffer只能依托于另一个server。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值