1、pom
<dependency>
<groupId>org.springframework.kafka</groupId>
<artifactId>spring-kafka</artifactId>
</dependency>
2、properties
#============== kafka one===================
spring.kafka.one.bootstrap-servers=${
kafka_bootstrap_servers:ip:port}
#===============one consumer =======================
spring.kafka.one.consumer.group-id=id
spring.kafka.one.consumer.auto-offset-reset=earliest
spring.kafka.one.consumer.enable-auto-commit=true
spring.kafka.one.consumer.auto-commit-interval=100
spring.kafka.one.consumer.max-poll-records=500
#============== kafka two===================
spring.kafka.two.bootstrap-servers=${
kafka_bootstrap_servers:ip:port}
#============two consumer =======================
spring.kafka.two.consumer.group-id=id
spring.kafka.two.consumer.auto-offset-reset=earliest
spring.kafka.two.consumer.enable-auto-commit=true
spring.kafka.two.consumer.auto-commit-interval=100
spring.kafka.two.consumer.max-poll-records=500
3、config
kafka one的配置
/**
* @author code
* @version 1.0
* @Date 2022/6/22 13:47
* @Description ${kafka-one}
*/
@EnableKafka
@Configuration
public class KafkaConfigOne {
@Value("${spring.kafka.one.bootstrap-servers}")
private String bootstrapServers;
@Value("${spring.kafka.one.consumer.group-id}")
private String groupId;
@Value("${spring.kafka.one.consumer.enable-auto-commit}")
private boolean enableAutoCommit;
@Value("${spring.kafka.one.consumer.auto-offset-reset}")
private String autoOffsetReset;
@Value("${spring.kafka.one.consumer.auto-commit-interval}")
private Integer autoCommitInterval;
@Value("${spring.kafka.one.consumer.max-poll-records}")
private Integer maxPollRecords;
@Bean
public KafkaTemplate<String, String> kafkaOneTemplate() {
return new KafkaTemplate<>(producerFactory());
}
@Bean
KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<Integer, String>> kafkaOneContainerFactory() {
ConcurrentKafkaListenerContainerFactory<Integer, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
factory.setConsumerFactory(consumerFactory());
factory.setConcurrency(3);
factory.setBatchListener(true);
factory.getContainerProperties().setPollTimeout(3000);
return factory;
}
private ProducerFactory<String, String> producerFactory() {
return new DefaultKafkaProducerFactory<>(producerConfigs());
}
public ConsumerFactory<Integer, String> consumerFactory() {
return new DefaultKafkaConsumerFactory<>(consumerConfigs());
}
private Map<String, Object> producerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(ProducerConfig.RETRIES_CONFIG,0);
props.put(ProducerConfig.ACKS_CONFIG,"1");
props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
return props;
}
private Map<String, Object> consumerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, enableAutoCommit);
props.put(ConsumerConfig.GROUP_ID_CONFIG,groupId);
props.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, autoCommitInterval);
props.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG,autoOffsetReset);
props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
return props;
}
}
kafka two的配置
/**
* @author code
* @version 1.0
* @Date 2022/6/22 14:16
* @Description ${kafka-two}
*/
@EnableKafka
@Configuration
public class KafkaConfigTwo {
@Value("${spring.kafka.two.bootstrap-servers}")
private String bootstrapServers;
@Value("${spring.kafka.two.consumer.group-id}")
private String groupId;
@Value("${spring.kafka.two.consumer.enable-auto-commit}")
private boolean enableAutoCommit;
@Value("${spring.kafka.two.consumer.auto-offset-reset}")
private String autoOffsetReset;
@Value("${spring.kafka.two.consumer.auto-commit-interval}")
private Integer autoCommitInterval;
@Value("${spring.kafka.two.consumer.max-poll-records}")
private Integer maxPollRecords;
@Bean
public KafkaTemplate<String, String> kafkaTwoTemplate() {
return new KafkaTemplate<>(producerFactory());
}
@Bean
KafkaListenerContainerFactory<ConcurrentMessageListenerContainer<Integer, String>> kafkaTwoContainerFactory() {
ConcurrentKafkaListenerContainerFactory<Integer, String> factory = new ConcurrentKafkaListenerContainerFactory<>();
factory.setConsumerFactory(consumerFactory());
factory.setConcurrency(3);
factory.setBatchListener(true);
factory.getContainerProperties().setPollTimeout(3000);
return factory;
}
private ProducerFactory<String, String> producerFactory() {
return new DefaultKafkaProducerFactory<>(producerConfigs());
}
public ConsumerFactory<Integer, String> consumerFactory() {
return new DefaultKafkaConsumerFactory<>(consumerConfigs());
}
private Map<String, Object> producerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(ProducerConfig.RETRIES_CONFIG,0);
props.put(ProducerConfig.ACKS_CONFIG,"1");
props.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class);
return props;
}
private Map<String, Object> consumerConfigs() {
Map<String, Object> props = new HashMap<>();
props.put(ConsumerConfig.BOOTSTRAP_SERVERS_CONFIG, bootstrapServers);
props.put(ConsumerConfig.ENABLE_AUTO_COMMIT_CONFIG, enableAutoCommit);
props.put(ConsumerConfig.GROUP_ID_CONFIG,groupId);
props.put(ConsumerConfig.AUTO_COMMIT_INTERVAL_MS_CONFIG, autoCommitInterval);
props.put(ConsumerConfig.AUTO_OFFSET_RESET_CONFIG,autoOffsetReset);
props.put(ConsumerConfig.KEY_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
props.put(ConsumerConfig.VALUE_DESERIALIZER_CLASS_CONFIG, StringDeserializer.class);
return props;
}
}
4、监听消息,指定kafka factory
@KafkaListener(topics = "topic",containerFactory = "kafkaOneContainerFactory")
5、主题配置在配置文件
kafka.topic=topic
@KafkaListener(topics = "#{'${kafka.topic}'.split(',')}",containerFactory = "kafkaOneContainerFactory")
6、发消息,指定kafkaTemplate
@Autowired
KafkaTemplate kafkaOneTemplate;