我有两个模式:
DataRecord.avsc:
{
"namespace": "com.mycompany",
"type": "record",
"name": "DataRecord",
"fields": [
{"name": "id", "type": ["null", "string"], "default": null},
{"name": "type", "type": ["null", "string"], "default": null},
{"name": "content", "type": ["null", "string"], "default": null},
{"name": "error", "type": ["null", "com.mycompany.Error"], "default": null}
]
}
Error.avsc:
{
"namespace": "com.mycompany",
"type": "error",
"name": "Error",
"fields": [
]
}
它与 Avro 1.8.2 一起工作,但在我升级到 Avro 1.9.0 并尝试构建之后,它无法编译并生成以下错误日志:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.5:compile (default-compile) on project avro-error-type-missing-custom-coding: Compilation failure: Compilation failure:
[ERROR] /workspaces/myspace/avro-error-type-missing-custom-coding/target/generated-sources/avro/com/mycompany/DataRecord.java:[570,17] cannot find symbol
[ERROR] symbol: method customEncode(org.apache.avro.io.Encoder)
[ERROR] location: variable error of type com.mycompany.Error
[ERROR] /workspaces/myspace/avro-error-type-missing-custom-coding/target/generated-sources/avro/com/mycompany/DataRecord.java:[608,19] cannot find symbol
[ERROR] symbol: method customDecode(org.apache.avro.io.ResolvingDecoder)
似乎SpecificRecordBase在Avro 1.9.0中有customEncode()
和customDecode()
方法,但SpecificExceptionBase没有。
我该如何解决这个问题?
最佳答案
确保在 pom.xml 中包含 Avro 依赖项。 来源:https://avro.apache.org/docs/1.11.1/getting-started-java/
<dependency>
<groupId>org.apache.avro</groupId>
<artifactId>avro</artifactId>
<version>1.11.1</version>
</dependency>
关于java - Avro 1.9.0 无法编译生成的 java 代码,错误消息为 : cannot find symbol method customEncode(org. apache.avro.io.Encoder),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56977080/