Avro是一种远程过程调用和数据序列化框架,是在ApacheHadoop项目之内开发的。它使用JSON来定义数据类型和通讯协议,使用压缩二进制格式来序列化数据。它主要用于Hadoop,它可以为持久化数据提供一种序列化格式,并为Hadoop节点间及从客户端程序到Hadoop服务的通讯提供一种电报格式。

Apache Avro
开发者Apache软件基金会
当前版本
  • 1.12.0(2024年8月5日;稳定版本)[1]
编辑维基数据链接
源代码库 编辑维基数据链接
类型远程过程调用框架
许可协议Apache许可证 2.0
网站https://avro.apache.org/

它类似于Thrift,但当数据库模式英语Database schema改变时,它不要求运行代码生成程序,除非是对静态类型的语言。

已有API的语言

编辑

虽然理论上任何语言都可以使用Avro,但是以下语言有专门为其编写的API:[2][3]

Avro IDL

编辑

为进一步支持JSON在类型及协议定义中使用,Avro包含了一种试验性的[6]替代性支持,它针对一种接口描述语言(IDL)语法,被称作Avro IDL。它以前被称为GenAvro,它设计了一种语法类似于C/C++、Protocol Buffers等的格式,以吸引那些熟悉传统IDL和编程语言的用户。

参见

编辑

参考文献

编辑
  1. ^ Release 1.12.0. 2024年8月5日 [2024年8月20日]. 
  2. ^ phunt. GitHub - phunt/avro-rpc-quickstart: Apache Avro RPC Quick Start.. GitHub. [2016年4月13日]. (原始内容存档于2020年11月9日). (英文)
  3. ^ 3.0 3.1 支持的语言 - Apache Avro - Apache软件基金会. [2016年4月21日]. (原始内容存档于2020年10月31日). (英文)
  4. ^ Avro: 1.5.1 - ASF JIRA. [2016年4月13日]. (原始内容存档于2016年4月25日). (英文)
  5. ^ [AVRO-533] Avro的.NET实现 - ASF JIRA. [2016年4月13日]. (原始内容存档于2020年10月25日). (英文)
  6. ^ Apache Avro 1.8.0 IDL. [2016年4月13日]. (原始内容存档于2010年9月20日). (英文)

扩展阅读

编辑