Kafka消费者发送消息

异步发送

Properties properties = new Properties();

// 连接集群
properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG,"hadoop102:9092,hadoop103:9092");

// 手动指定序列化器
properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
        
properties.put("client.username","jdq账号");
properties.put("client.password","jdq密码");

KafkaProducer<String, String> kafkaProducer = new KafkaProducer<String, String>(properties);
kafkaProducer.send(new ProducerRecord<>("String","String"));
kafkaProducer.close();

注意,jdq需要指定username和password。

回调异步发送

返回值实际上是等待队列发送的消息,且发送失败后会自动重试,不需要我们手动进行重试

@Slf4j
public class CustomProduct {

    public static void main(String[] args) {

        Properties properties = new Properties();

        // 连接集群
        properties.put(ProducerConfig.BOOTSTRAP_SERVERS_CONFIG, "hadoop102:9092,hadoop103:9092");

        // 手动指定序列化器
        properties.put(ProducerConfig.KEY_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());
        properties.put(ProducerConfig.VALUE_SERIALIZER_CLASS_CONFIG, StringSerializer.class.getName());

        properties.put("client.username", "jdq账号");
        properties.put("client.password", "jdq密码");


        KafkaProducer<String, String> kafkaProducer = new KafkaProducer<>(properties);
        Future<RecordMetadata> send = kafkaProducer.send(new ProducerRecord<>("String", "String"));
        kafkaProducer.send(new ProducerRecord<>("String", "String"), (recordMetadata, e) -> {
            if (e == null) {
                log.info("主题:{},分区:{}",recordMetadata.topic(),recordMetadata.partition());
            }
        });
        kafkaProducer.close();


    }

}

同步发送 

同步发送是指,发送到等待队列中的数据,必须等待消息已经发送到kafka集群中,生产者才会发送下一条消息。即等待队列等待数据累计到batch.size或者时间到达linger.ms之后,通过sender发送到kafka集群中,再根据ack应答的登记,最后由selector决定删除信息还是重试,最后直到清理队列中的消息,消费者再发送下一条数据。

同步发送的标志是让send方法有返回值,即

Future<RecordMetadata> send = kafkaProducer.send(new ProducerRecord<>("String", "String"));

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值