Beam WordCount Docker镜像在使用AvroCoderregistrar的Flink Runner上启动失败,出现了“Not a SubType”异常。
创始人
2024-11-27 01:30:31
0

出现"Not a SubType"异常通常是由于AvroCoder注册器无法正确识别Avro类型导致的。以下是解决方法的代码示例:

  1. 确保Avro类型已正确注册:
import org.apache.avro.generic.GenericRecord;
import org.apache.avro.reflect.ReflectData;

public class AvroTypeRegistrar {
    public static void registerAvroTypes() {
        ReflectData.get().getSchema(SomeAvroType.class);
        // 注册其他Avro类型
    }
}

在Flink job启动前调用AvroTypeRegistrar.registerAvroTypes()方法,确保所有Avro类型已正确注册。

  1. 如果使用的是Flink Streaming Job,可以在StreamExecutionEnvironment中注册Avro类型:
import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
import org.apache.flink.api.java.typeutils.TypeExtractor;

public class FlinkJob {
    public static void main(String[] args) throws Exception {
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        
        // 注册Avro类型
        env.getConfig().registerTypeWithKryoSerializer(SomeAvroType.class, SpecificAvroSerializer.class);
        // 注册其他Avro类型
        
        // 添加其他Flink job代码
        
        env.execute("Flink Job");
    }
}

使用env.getConfig().registerTypeWithKryoSerializer()方法注册Avro类型。

  1. 如果上述方法仍然无法解决问题,可以尝试使用AvroCoder.of()方法手动注册Avro类型:
import org.apache.avro.generic.GenericData;
import org.apache.beam.sdk.coders.AvroCoder;
import org.apache.beam.sdk.coders.CoderRegistry;

public class AvroTypeRegistrar {
    public static void registerAvroTypes() {
        CoderRegistry coderRegistry = CoderRegistry.createDefault();
        
        // 注册Avro类型
        coderRegistry.registerCoderForClass(SomeAvroType.class, AvroCoder.of(SomeAvroType.class));
        // 注册其他Avro类型
        
        // 设置CoderRegistry到PipelineOptions
        GenericData.setCoderRegistry(coderRegistry);
    }
}

在Flink job启动前调用AvroTypeRegistrar.registerAvroTypes()方法,手动注册Avro类型。

通过以上解决方法,您应该能够解决在使用AvroCoderRegistrar的Flink Runner上启动Beam WordCount Docker镜像时出现的"Not a SubType"异常。

相关内容

热门资讯

线上(wepoke真的)原来是... 线上(wepoke真的)原来是真的有挂!其实真的有挂(2022已更新)(哔哩哔哩);亲,其实确实真的...
两教程(Wepoke程序)软件... 两教程(Wepoke程序)软件透明挂辅助工具(软件透明挂)透视辅助(2024已更新)(哔哩哔哩);致...
软件(wepoke透明)原来是... 软件(wepoke透明)原来是真的有挂!其实真的有挂(2020已更新)(哔哩哔哩)是一款可以让一直输...
一模拟器(德扑工具)外挂辅助工... 一模拟器(德扑工具)外挂辅助工具(透视)透视辅助(2025已更新)(哔哩哔哩);亲真的是有正版授权,...
系统(aapoker讲解)竟然... 系统(aapoker讲解)竟然真的有挂!其实真的有挂(2021已更新)(哔哩哔哩);aapoker讲...
6系统(aapoker下载)外... 6系统(aapoker下载)外挂辅助工具(辅助挂)透视辅助(2023已更新)(哔哩哔哩)aapoke...
智能(德扑之星刷数据)果真真的... 智能(德扑之星刷数据)果真真的有挂!原来真的有挂(2025已更新)(哔哩哔哩);《WPK辅助透视》‌...
1机器人(德州nzt软件)软件... 1机器人(德州nzt软件)软件透明挂辅助软件(透视)透视辅助(2022已更新)(哔哩哔哩);人气非常...
ai代打(德扑之星决策)确实是... ai代打(德扑之星决策)确实是真的有挂!原来真的有挂(2020已更新)(哔哩哔哩);科技详细教程小薇...
第8透明(wepoke数据)外... 第8透明(wepoke数据)外挂透明挂辅助神器(辅助挂)透视辅助(2023已更新)(哔哩哔哩);原来...