java spring kafkaTemplate 同步发送消息

本文介绍了一种使用Kafka进行同步消息发送的方法。通过@Value注解读取配置文件中的topic,创建ProducerRecord并利用kafkaTemplate进行消息发送。采用ListenableFuture异步回调机制,确保消息成功发送,同时在指定时间内等待发送完成。
@Value("${kafka.topic}")
private String topic;

public boolean sendMsgSync(String key, String msg) {
    logger.info(">>>>>------producer msg: [{}]", msg);

    final boolean[] ok = {true};
    ProducerRecord<String, String> record = new ProducerRecord<>(topic, key, msg);
    ListenableFuture<SendResult<String, String>> future = kafkaTemplate.send(record);
    future.addCallback(new ListenableFutureCallback<SendResult<String, String>>() {
        @Override
        public void onFailure(@NonNull Throwable throwable) {
            logger.error("sent message=[{}] failed!", msg, throwable);
            ok[0] = false;
        }

        @Override
        public void onSuccess(SendResult<String, String> result) {
            logger.info("sent message=[{}] with offset=[{}] success!", msg, result.getRecordMetadata().offset());
        }
    });
    try {
        // 因为是异步发送,所以我们等待,最多10s
        future.get(10, TimeUnit.SECONDS);
    } catch (InterruptedException | ExecutionException | TimeoutException e) {
        logger.error("waiting for kafka send finish failed!", e);
        return false;
    }
    return ok[0];
}

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值