kafka-事务

1. 事务的5个API

java 复制代码
// 1初始化事务
void initTransactions();

// 2开启事务
void beginTransaction() throws ProducerFencedException;

// 3在事务内提交已经消费的偏移量(主要用于消费者)
void sendOffsetsToTransaction(Map<TopicPartition, OffsetAndMetadata> offsets,
                              String consumerGroupId) throws ProducerFencedException;

// 4提交事务
void commitTransaction() throws ProducerFencedException;

// 5放弃事务(类似于回滚事务的操作)
void abortTransaction() throws ProducerFencedException;

2. 幂等性和事务性的关系

事务属性实现前提是幂等性,即在配置事务属性transaction id时,必须还得配置幂等性;但是幂等性是可以独立使用的,不需要依赖事务属性。

  1. 幂等性引入了Porducer ID
  2. 事务属性引入了Transaction Id属性。

使用场景

  1. enable.idempotence = true,transactional.id不设置:只支持幂等性。
  2. enable.idempotence = true,transactional.id设置:支持事务属性和幂等性
  3. enable.idempotence = false,transactional.id不设置:没有事务属性和幂等性的kafka
  4. enable.idempotence = false,transactional.id设置:无法获取到PID,此时会报错

3. 参考

kafka幂等生产者及事务_51CTO博客_kafka事务

相关推荐
却话巴山夜雨时i1 小时前
Java面试实录:从Spring Boot到Kafka的技术探讨
spring boot·微服务·kafka·grafana·prometheus·java面试
Abcdzzr2 小时前
2026/4/6 Windows安装Kafka
分布式·kafka
Devin~Y3 小时前
高并发内容社区实战面试:从 Java 基础到 Spring Cloud、Kafka、Redis、RAG 搜索全解析
java·spring boot·redis·spring cloud·kafka·向量数据库·rag
学到头秃的suhian3 小时前
Kafka高性能
kafka
aP8PfmxS215 小时前
从零学习Kafka:数据存储
分布式·学习·kafka
bIo7lyA8v20 小时前
从零学习Kafka:集群架构和基本概念
学习·架构·kafka
学到头秃的suhian20 小时前
Kafka高可用
kafka
DYuW5gBmH1 天前
Kafka 成功消费消息的完整流程图
分布式·kafka·流程图
学到头秃的suhian2 天前
消息队列发送消息场景分析
kafka
zs宝来了3 天前
Kafka 存储原理:索引文件与日志段管理
kafka·存储·索引·源码解析·日志段