0

我有一个用例,其中传入的数据有一个标识不同类型数据的键。有一个单一的输入 kafka 主题,所有类型的数据都被抛出。光束管道从输入的 kafka 主题读取所有消息,并且必须根据密钥路由到不同的 kafka 主题。

目前,KafkaIO 不支持使用单个生产者写入多个主题。以下代码是内部工作代码KafkaIO.write()

final class AutoValue_KafkaIO_Write<K, V> extends Write<K, V> {
    private final String topic;
    private final WriteRecords<K, V> writeRecordsTransform;

    private AutoValue_KafkaIO_Write(@Nullable String topic, WriteRecords<K, V> writeRecordsTransform) {
        this.topic = topic;
        this.writeRecordsTransform = writeRecordsTransform;
    }

如何使用 apache Beam 的 kafkaIO 生产者来做到这一点?

4

1 回答 1

0

经过几天尝试实现消息路由,目前kafkaIO不支持消息路由到不同主题。

一种解决方法是为每个不同的主题创建一个 kafka 生产者,并根据发送到不同 kafka 主题的元素将元素隔离到不同的 pcollections。

于 2020-07-05T19:53:46.660 回答