kafka发送消息流程

配置props.put(ProducerConfig.PARTITIONER_CLASS_CONFIG, RoundRobinPartitioner.class);

java 复制代码
public Map<String,Object> producerConfigs(){
    Map<String,Object> props = new HashMap<>();
    props.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,bootstrapServers);
    props.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG,valueSerializer);
    props.put(ProducerConfig.PARTITIONER_CLASS_CONFIG, RoundRobinPartitioner.class);
    return props;
}

public ProducerFactory producerFactory(){
    return new DefaultKafkaProducerFactory<>(producerConfigs());
}

// 覆盖spring-kafka中的配置
@Bean
public KafkaTemplate<String,Object> kafkaTemplate(){
    return new KafkaTemplate<String,Object>(producerFactory());
}

自定义消息拦截器

java 复制代码
public class CustomerProducerInterceptor implements ProducerInterceptor<String,Object> {

    // 发送消息时,对消息拦截。
    @Override
    public ProducerRecord<String,Object> onSend(ProducerRecord producerRecord) {
        System.out.println("拦截消息" + producerRecord.toString());
        return null;
    }

    // 服务器是否收到了当前这条消息
    @Override
    public void onAcknowledgement(RecordMetadata recordMetadata, Exception e) {
        if(recordMetadata != null){
            System.out.println("服务器收到消息" + recordMetadata.offset());
        }else{
            // 没有收到消息发送失败
            System.out.println("消息发送失败!!!");
        }
    }

    @Override
    public void close() {

    }

    @Override
    public void configure(Map<String, ?> map) {

    }
}
相关推荐
爱打lan球的程序员7 小时前
redis分布式锁和lua脚本
数据库·redis·分布式
晚睡早起₍˄·͈༝·͈˄*₎◞ ̑̑12 小时前
苍穹外卖学习笔记(一)
java·笔记·学习·spring·kafka·tomcat·maven
流烟默14 小时前
Kafka【十三】消费者消费消息的偏移量
分布式·kafka·消费偏移量
Casual_Lei15 小时前
Spark的一些高级用法
大数据·分布式·spark
安科瑞蒋静18 小时前
安科瑞Acrel-1000DP分布式光伏监控系统平台的设计与应用-安科瑞 蒋静
分布式
码码哈哈0.021 小时前
每天一道面试题(5):Kafka 的零拷贝原理
分布式·kafka
Casual_Lei21 小时前
Kafka 常用的传输和序列化数据方式
分布式·kafka
slb19062321 小时前
Kafka 分布式消息系统详细介绍
分布式·kafka·kafka 分布式消息系统
武子康1 天前
大数据-123 - Flink 并行度 相关概念 全局、作业、算子、Slot并行度 Flink并行度设置与测试
java·大数据·分布式·flink·spark
九品神元师1 天前
Kafka命令
分布式·zookeeper·kafka