Avro模式中的多态性和继承

 黑天鹅猪猪_251 发布于 2023-02-07 11:48

是否可以编写一个Avro架构/ IDL来生成扩展基类或实现接口的Java类?似乎生成的Java类扩展了org.apache.avro.specific.SpecificRecordBase.因此,工具可能是要走的路.但是,我不知道这是否可行.

我已经看到了一些示例,其中提出了在每个特定模式中定义显式"类型"字段的建议,其中包含的关联多于继承语义.

我在我的工厂类和代码的其他部分中大量使用我的基类.目前,我有从JSON Schema生成的代码,它支持继承.

另一个问题是:你可以使用IDL来定义没有协议定义的记录吗?我认为答案是否定的,因为编译器抱怨缺少协议关键字.

帮助赞赏!谢谢.

1 个回答
  • 我找到了解决这个问题的更好方法.看一下Avro中的Schema生成源,我发现在类内部,类生成逻辑使用Velocity模式来生成类.

    我修改了record.vm模板以实现我的特定接口.有一种方法可以使用templateDirectorymaven构建插件中的配置指定velocity目录的位置.

    我也转而使用SpecificDatumWriter而不是reflectDatumWriter.

    <plugin>
      <groupId>org.apache.avro</groupId>
      <artifactId>avro-maven-plugin</artifactId>
       <version>${avro.version}</version>
       <executions>
        <execution>
          <phase>generate-sources</phase>
          <goals>
            <goal>schema</goal>
          </goals>
          <configuration>
             <sourceDirectory>${basedir}/src/main/resources/avro/schema</sourceDirectory>
             <outputDirectory>${basedir}/target/java-gen</outputDirectory>
             <fieldVisibility>private</fieldVisibility>
             <stringType>String</stringType>
             <templateDirectory>${basedir}/src/main/resources/avro/velocity-templates/</templateDirectory>
           </configuration>
        </execution>
      </executions>
    </plugin>
    

    2023-02-07 11:49 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有