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事务

相关推荐
johnny23317 小时前
Kafka系列之脚本使用
kafka
BD_Marathon17 小时前
【Kafka】
分布式·kafka
昵称为空C21 小时前
kafka的替代品redpanda部署与SpringBoot集成使用案例
spring boot·后端·kafka
if_else人生1 天前
人工智能与区块链:打造未来数字经济的新基石
kafka
2501_941810831 天前
5G技术:如何推动智慧城市建设,提升城市管理与生活质量
kafka
lang201509281 天前
Kafka延迟操作机制深度解析
分布式·python·kafka
2501_941624332 天前
云计算与边缘计算:未来数字化转型的双引擎
kafka
while(努力):进步2 天前
人工智能的未来:如何改变我们的工作与生活
kafka
2501_941403762 天前
人工智能与机器学习:未来科技的核心驱动力
kafka
一只会写代码的猫2 天前
云原生与编程语言:如何应对现代应用的复杂性挑战
kafka