当前位置: 首页 > news >正文

java 给鉴权kafka2.7(sasl)发送消息权限异常处理

报错:org.apache.kafka.common.KafkaException: Cannot execute transactional method because we are in an error state at org.apache.kafka.clients.producer.internals.TransactionManager.maybeFailWithError(TransactionManager.java:1125) at org.apache.kafka.clients.producer.internals.TransactionManager.maybeAddPartition(TransactionManager.java:442) at org.apache.kafka.clients.producer.KafkaProducer.doSend(KafkaProducer.java:1000) at org.apache.kafka.clients.producer.KafkaProducer.send(KafkaProducer.java:914) at kafka.tools.ConsoleProducer.send(ConsoleProducer.scala:71)atkafka.tools.ConsoleProducer.send(ConsoleProducer.scala:71) at kafka.tools.ConsoleProducer.send(ConsoleProducer.scala:71)atkafka.tools.ConsoleProducer.main(ConsoleProducer.scala:53) at kafka.tools.ConsoleProducer.main(ConsoleProducer.scala) Caused by: org.apache.kafka.common.errors.ClusterAuthorizationException: Cluster authorization failed. [2025-11-14 09:17:42,327] ERROR [Producer clientId=console-producer] Aborting producer batches due to fatal error (org.apache.kafka.clients.producer.internals.Sender) org.apache.kafka.common.errors.ClusterAuthorizationException: Cluster authorization failed. [2025-11-14 09:17:42,331] ERROR Error when sending message to topic test_topic with key: null, value: 1 bytes with error: (org.apache.kafka.clients.producer.internals.ErrorLoggingCallback) org.apache.kafka.common.errors.ClusterAuthorizationException: Cluster authorization failed.

问题描述:java使用的kafka3.1版本client,sink端kakfa是2.7开启了sasl,生产消息报错
小飞,这个报错非常典型
✔️ 跨版本(Kafka 3.1 → Kafka 2.7)
✔️ SASL 启动
✔️ 报 ClusterAuthorizationException
✔️ 2.7→2.7 正常,3.1→2.7 不正常

问题本质:Kafka 3.1 的 Producer 启用了事务(Transactional API),但 Kafka 2.7 端不支持或未授权。

你现在的报错完全符合 生产者端「自动启用事务」或「默认使用幂等性」与 Broker 权限不匹配


🔥 一、报错核心原因分析

日志关键点👇:

KafkaException: Cannot execute transactional method because we are in an error state
Caused by: ClusterAuthorizationException: Cluster authorization failed.

这说明两件事:

① Producer 在使用事务性 API(transactional.id)

不管你是否手写过 transactional.id
Console-producer 默认启用了幂等性(Idempotence)和事务相关的校验
Kafka 3.0+ 默认开启功能比 2.x 多,导致连接 2.7 时:

  • 要求 broker 允许 Idempotent Producer(需要权限 IdempotentWrite
  • 要求写入事务日志(需要 TransactionalId 权限)
  • 要求更高的集群授权(需要 Cluster:AlterCluster:Describe 等)

但你的 Kafka 2.7 根本没给这些权限,所以:

➡️ 直接报 ClusterAuthorizationException


🔥 二、为什么 2.7→2.7 没问题?

因为:

  • 2.7 客户端默认不开事务(console-producer 默认不启用)
  • 2.7 broker 对事务权限要求低(甚至可以关闭)
  • SASL 认证和权限体系与 3.1 对接时不完全兼容

所以版本兼容性问题 + 权限不足 = 报错


🔥 三、最常见的触发场景

✔️ 1. 3.1默认配置了:

enable.idempotence=true

transactional.id=my-tx

✔️ 2. 或 producer 默认使用了幂等性(Kafka 3.1 默认开启)

Kafka 3.0 之后 producer 默认:

  • enable.idempotence=true
  • 需要能力:IdempotentWriter

但是你的 Kafka 2.7 没配置 ACL 允许它写入集群级元数据


🔥 四、解决方案(按推荐顺序)


方案 1:禁用 idempotence 与事务(最简方式)

producer.conf 添加:

enable.idempotence=false

如果你使用 console producer,则命令:

../kafka/bin/kafka-console-producer.sh \--bootstrap-server xxx:9092 \--topic test_topic \--producer.config producer.conf

注意:Kafka 3.0+ 默认开启幂等性 → 必须显式关闭

通过 properties配置解决了
properties:
enable:
idempotence: false

---
http://www.dtcms.com/a/609602.html

相关文章:

  • 手机论坛网站源码和卫通app下载
  • 零基础学JAVA--Day32(ArrayList底层+Vector+LinkedList)
  • 了解Bootstrap ——初学者
  • 启动Nginx
  • 手机编程网站网站建设软件是什么意思
  • 设计兼职网站推荐自己做的网站网页错位
  • 第1章 机器学习的诞生与演化
  • 从零开始刷算法——二分-搜索旋转排序数组
  • Spring Boot + Vue 全栈开发实战指南
  • 深度智能体-人机回环
  • ASC学习笔记0013:添加一个新的属性集(初始化为默认值)
  • SpringIOC-注解
  • 关闭网站跳转代码wordpress 图片云存储
  • Java练习——数组练习
  • 导航仪企业网站源码那个网站做拍手比较好
  • 离别的十字路口: 是否还记得曾经追求的梦想
  • 3D地球可视化教程 - 第4篇:第5篇:星空背景与粒子系统
  • Unity Shader Graph 3D 实例 - 一个简单的红外线扫描全身效果
  • 【Mastergo】Mastergo总览
  • steam安装游戏为什么磁盘写入错误?磁盘写入错误怎么办?,同样问题解决方案
  • Unity官方文档 Asset Workflow:Importing Assets 阅读笔记
  • UD动作游戏开发读书笔记--. D游戏所需要的数学知识
  • 网站多语切换怎么做网站跳出率多少合适
  • MySQL数据类型全面解析:从数值精度到字符串优化的最佳实践
  • 太阳光模拟器应用:汽车太阳能天窗的发电效能动态测试
  • ES踩了一坑 script查询与float类型的精度
  • ASC学习笔记0015:此能力系统组件是否具有此属性?
  • 如何基于DSL脚本进行elasticsearch向量检索示例
  • 如何利用大语言模型(LLM)实现自动标注与内容增强
  • h5网站有哪些网页设计公司的目标客户有哪些