是否可以编写一个Avro架构/ IDL来生成扩展基类或实现接口的Java类?似乎生成的Java类扩展了org.apache.avro.specific.SpecificRecordBase
.因此,工具可能是要走的路.但是,我不知道这是否可行.
我已经看到了一些示例,其中提出了在每个特定模式中定义显式"类型"字段的建议,其中包含的关联多于继承语义.
我在我的工厂类和代码的其他部分中大量使用我的基类
.目前,我有从JSON Schema生成的代码,它支持继承.
另一个问题是:你可以使用IDL来定义没有协议定义的记录吗?我认为答案是否定的,因为编译器抱怨缺少协议关键字.
帮助赞赏!谢谢.
我找到了解决这个问题的更好方法.看一下Avro中的Schema生成源,我发现在类内部,类生成逻辑使用Velocity模式来生成类.
我修改了record.vm
模板以实现我的特定接口.有一种方法可以使用templateDirectory
maven构建插件中的配置指定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>