通过使用这个tutorial,我能够创建一个简单的生产者-消费者示例。在我的示例中,只有一个主题,而我正在收听这个主题。因此,ReceiverConfig
中的代码是有意义的。特别是关于GROUP_ID_CONFIG
的一点,即我创建了主题topic_name
,然后在这个配置中进行了配置。现在我的问题是,如果我有一个以上的主题怎么办。假设我有topic_1
、topic_2
等等?我应该为每个单独的主题创建ReceiverConfig
吗?
@EnableKafka
@Configuration
public class ReceiverConfig {
@Value("${spring.kafka.bootstrap-servers}")
private String bootstrapServers;
@Bean
public Map<String, Object> consumerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(GROUP_ID_CONFIG, "topic_name");
props.put(AUTO_OFFSET_RESET_CONFIG, "earliest");
return props;
}
@Bean
public ConsumerFactory<String, String> consumerFactory() {
return new DefaultKafkaConsumerFactory<>(consumerConfigs());
}
@Bean
public KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<String, String>> kafkaListenerContainerFactory() {
ConcurrentKafkaListenerContainerFactory<String, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
factory.setConsumerFactory(consumerFactory());
return factory;
}
}
https://stackoverflow.com/questions/50777283
复制相似问题