Flink(九)Flink自定义Sink注入Spring容器

一、配置Flink相关属性

public class FlinkKafkaStreaming {

	/**
	 * 加载Kafka配置
	 */
	@Autowired
	private KafkaProperties kafkaProperties;

	public void main(String[] args) throws Exception {
        // 流处理
        StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
        Properties properties = new Properties();
        properties.putAll(kafkaProperties.buildConsumerProperties());
        FlinkKafkaConsumer<String> consumer = new FlinkKafkaConsumer<>(KafkaTopicName, new SimpleStringSchema(), properties);
        DataStreamSource<String> source = env.addSource(consumer);
		
        // ...相关算子操作

        recordData.addSink(new MySink());
        env.execute();
	}
}

二、自定义Sink使用@Autowired注入Spring容器中的类

public class MySink extends RichSinkFunction<Bean> {

        @Autowired
	private MyService myService;

	/**
	 * Flink Sink执行方法
	 */
	@Override
	public void invoke(Bean bean, Context context) throws Exception {
            // 使用myService时发现空指针异常
	}

}

分析:在启动SpringBoot项目是加载了Spring容器,其他地方可以使用@Autowired获取Spring容器中的类;但是Flink启动的项目中,默认启动了多线程执行相关代码,导致在其他线程无法获取Spring容器,只有在Spring所在的线程才能使用@Autowired,故在Flink自定义的Sink的open()方法中初始化Spring容器,示例代码如下:

public class MySink extends RichSinkFunction<Bean> {

	private MyService myService;

	/**
	 * 在open()方法中动态注入Spring容器的类
	 */
	@Override
	public void open(Configuration parameters) throws Exception {
            super.open(parameters);
            myService = ApplicationContextUtil.getBean(myServiceImpl.class);
	}

	/**
	 * Flink Sink执行方法
	 */
	@Override
	public void invoke(Bean bean, Context context) throws Exception {
            // 可以正常使用myService
	}

}

三、SpringBoot动态加载Spring容器的类

@Component
public class ApplicationContextUtil implements ApplicationContextAware, Serializable {

	/**
	 * 上下文
	 */
	private static ApplicationContext context;

	@Override
	public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
            this.context = applicationContext;
	}

	public static ApplicationContext getApplicationContext() {
            return context;
	}

	public static <T> T getBean(Class<T> beanClass) {
            return context.getBean(beanClass);
	}
}

 

  • 1
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值