java - Avro 1.9.0 无法编译生成的 java 代码,错误消息为 : cannot f

我有两个模式:

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/

相关文章:

spring - 无法解析 OpenID 配置 spring boot(安全)java.net.Co

python - 在多处理模块中使用 Pool 修改全局变量

angular - 自动滚动 onkeydown 即使没有必要

node.js - 事件.js :180 throw er;//Unhandled 'error'

r - 从 R Survey 包运行 svymean 时,我可以得到 unwtd.count 吗?

c# - Visual Studio 2019 不在 Mac 上强调错误

reactjs - 如何将 MenuItem 用作 NavLink?

laravel - 安装后如何使用 npm 包 (chart.js)?

sql-server - 如何查找从今天开始的同一工作日值的过去 4 周

angular - 上传 PUT 请求由 Angular ServiceWorker 发送两次