0


【FLink消费Kafka之FlinkConsumer到KafkaSource的转变】


前言

上篇介绍了flink的入门程序wordcount,在项目开发过程中,最常接触的还是跟各种源头系统打交道,其中消费接收kafka中的数据是最常见的情况,而flink在1.15版本后连接kafka的依赖包发生了变化,之前的flink版本使用的依赖包是flink-connector-kafka_2.1x(后面的数字代表kafka环境的scala版本),从flink1.15版本开始引用的依赖包变为flink-connector-kafka,具体的maven配置信息如下:


  1. 提示:以下为flink1.14及以下版本maven配置:
  1. <dependency><groupId>org.apache.flink</groupId><artifactId>flink-connector-kafka_2.12</artifactId><version>${flink.vesrion}</version></dependency>
  1. 提示:以下为flink1.15及以上版本maven配置:
  1. <dependency><groupId>org.apache.flink</groupId><artifactId>flink-connector-kafka</artifactId><version>${flink.vesrion}</version></dependency>

一、FlinkConsumer消费kafka

FlinkConsumer使用起来感觉和普通的kafka consumer java api差不多

  1. import org.apache.flink.api.common.serialization.SimpleStringSchema;import org.apache.flink.streaming.api.datastream.DataStream;import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;import org.apache.flink.streaming.connectors.kafka.FlinkKafkaConsumer;import java.util.Properties;
  2. public class FlinkConsumerTest {
  3. public static void main(String[] args) throws Exception {
  4. StreamExecutionEnvironment env= StreamExecutionEnvironment.getExecutionEnvironment();
  5. Properties properties = new Properties();
  6. properties.setProperty("bootstrap.servers","cdp1:9092");
  7. properties.setProperty("group.id","tes");
  8. properties.setProperty("key.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
  9. properties.setProperty("value.deserializer","org.apache.kafka.common.serialization.StringDeserializer");
  10. properties.setProperty("auto.offset.rest","latest");
  11. FlinkKafkaConsumer consumer = new FlinkKafkaConsumer<>("event_topic",new SimpleStringSchema(),properties);
  12. consumer.setStartFromLatest();
  13. DataStream<String> stream = env.addSource(consumer);
  14. stream.print();
  15. env.execute();}}

二、KafkaSource消费kafka

FlinkConsumer在flink1.15版本后,已经被弃用,推出了新的消费kafka的KafkaSource,文档地址为https://nightlies.apache.org/flink/flink-docs-release-1.17/docs/connectors/datastream/kafka/

  1. import org.apache.flink.api.common.eventtime.WatermarkStrategy;
  2. import org.apache.flink.api.common.serialization.SimpleStringSchema;
  3. import org.apache.flink.connector.kafka.source.KafkaSource;
  4. import org.apache.flink.connector.kafka.source.enumerator.initializer.OffsetsInitializer;
  5. import org.apache.flink.streaming.api.datastream.DataStreamSource;
  6. import org.apache.flink.streaming.api.environment.StreamExecutionEnvironment;
  7. public class KafkaSourceTest {
  8. public staticvoidmain(String[] args) throws Exception {
  9. StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment();
  10. KafkaSource<String> source = KafkaSource.<String>builder().setBootstrapServers("cdp1:9092").setGroupId("my_group").setTopics("event_topic").setStartingOffsets(OffsetsInitializer.latest()).setValueOnlyDeserializer(new SimpleStringSchema()).build();
  11. DataStreamSource<String> kafkaDS = env.fromSource(source, WatermarkStrategy.noWatermarks(),"kafka source");
  12. kafkaDS.print();
  13. env.execute();}}

总结

改用了FLink新版本的KafkaSource后,感觉代码比之前更加简洁清晰了,但具体使用原理都差不多的,在不同版本消费kafka数据时,需要注意的是,容易出现版本不兼容的问题,最常见的错误:java.lang.NoSuchMethodError: org.apache.kafka.clients.consumer.KafkaConsumer.poll,(可通过清理maven依赖、检查端口是否能连接,以及重启等等),今天只是简单聊了下kafkasource,其实新版本的flink中还提供了kafkasink,可以直接将接收的数据流sink到指定的位置,比如hdfs或者另外一个kafka集群,由于篇幅有限,这里就不具体展开了,后续会结合实际场景持续更新。

标签: flink kafka 大数据

本文转载自: https://blog.csdn.net/weixin_43153588/article/details/135121634
版权归原作者 以茉萱 所有, 如有侵权,请联系我们删除。

“【FLink消费Kafka之FlinkConsumer到KafkaSource的转变】”的评论:

还没有评论