Flink CDC 读取 MySQL 报错解决

报错内容

Flink CDC 读取 MySQL 的用户有需要表的读写权限,但是报错。

less 复制代码
io.debezium.DebeziumException: Access denied; you need (at least one of) the REPLICATION SLAVE privilege(s) for this operation Error code: 1227; SQLSTATE: 42000.
	at io.debezium.connector.mysql.MySqlStreamingChangeEventSource.wrap(MySqlStreamingChangeEventSource.java:1489) ~[flink-1.0.jar:?]
	at io.debezium.connector.mysql.MySqlStreamingChangeEventSource$ReaderThreadLifecycleListener.onCommunicationFailure(MySqlStreamingChangeEventSource.java:1545) [flink-1.0.jar:?]
	at com.github.shyiko.mysql.binlog.BinaryLogClient.listenForEventPackets(BinaryLogClient.java:1079) [flink-1.0.jar:?]
	at com.github.shyiko.mysql.binlog.BinaryLogClient.connect(BinaryLogClient.java:631) [flink-1.0.jar:?]
	at com.github.shyiko.mysql.binlog.BinaryLogClient$7.run(BinaryLogClient.java:932) [flink-1.0.jar:?]
	at java.lang.Thread.run(Thread.java:748) [?:1.8.0_202]
Caused by: com.github.shyiko.mysql.binlog.network.ServerException: Access denied; you need (at least one of) the REPLICATION SLAVE privilege(s) for this operation
	at com.github.shyiko.mysql.binlog.BinaryLogClient.listenForEventPackets(BinaryLogClient.java:1043) ~[flink-1.0.jar:?]
	... 3 more

问题原因

错误信息提示你需要REPLICATION SLAVE权限。这个权限允许用户从MySQL主服务器复制(读取)二进制日志,这是进行MySQL复制所必须的权限。在你的情况下,Flink的Debezium connector正在尝试读取二进制日志以获取数据库的变更事件,因此需要这个权限。

解决方法

sql 复制代码
GRANT REPLICATION CLIENT ON *.* TO 'flink'@'%';
GRANT REPLICATION SLAVE ON *.* TO 'flink'@'%';
FLUSH PRIVILEGES;
  • REPLICATION CLIENT权限允许用户查询主服务器的二进制日志状态(通过SHOW MASTER STATUS命令)和从服务器的状态(通过SHOW SLAVE STATUS命令)。这个权限通常用于监控和管理MySQL的主从复制。

  • REPLICATION SLAVE权限允许用户从主服务器复制(读取)二进制日志。这是进行MySQL复制所必需的权限,也是Flink的Debezium connector需要的权限。

  • MySQL中,REPLICATION CLIENTREPLICATION SLAVE是全局级别的权限,不能被授予特定的数据库或表

相关推荐
程序员张31 小时前
SpringBoot计时一次请求耗时
java·spring boot·后端
程序员岳焱7 小时前
Java 与 MySQL 性能优化:Java 实现百万数据分批次插入的最佳实践
后端·mysql·性能优化
麦兜*7 小时前
Spring Boot启动优化7板斧(延迟初始化、组件扫描精准打击、JVM参数调优):砍掉70%启动时间的魔鬼实践
java·jvm·spring boot·后端·spring·spring cloud·系统架构
大只鹅8 小时前
解决 Spring Boot 对 Elasticsearch 字段没有小驼峰映射的问题
spring boot·后端·elasticsearch
ai小鬼头8 小时前
AIStarter如何快速部署Stable Diffusion?**新手也能轻松上手的AI绘图
前端·后端·github
IT_10248 小时前
Spring Boot项目开发实战销售管理系统——数据库设计!
java·开发语言·数据库·spring boot·后端·oracle
bobz9659 小时前
动态规划
后端
stark张宇9 小时前
VMware 虚拟机装 Linux Centos 7.9 保姆级教程(附资源包)
linux·后端
亚力山大抵10 小时前
实验六-使用PyMySQL数据存储的Flask登录系统-实验七-集成Flask-SocketIO的实时通信系统
后端·python·flask
超级小忍10 小时前
Spring Boot 中常用的工具类库及其使用示例(完整版)
spring boot·后端