Cannot discover a connector using option: ‘connector‘=‘hbase-2.2‘

"在尝试使用Flink写入HBase时遇到了错误:无法发现使用'connector'='hbase-2.2'的连接器。错误提示表明在类路径中找不到实现'org.apache.flink.table.factories.DynamicTableFactory'的'hbase-2.2'工厂。解决方法是将flink-connector-hbase-2.2_2.11-${flink.version}
摘要由CSDN通过智能技术生成

Cannot discover a connector using option: 'connector'='hbase-2.2'

Could not find any factory for identifier 'hbase-2.2' that implements 'org.apache.flink.table.factories.DynamicTableFactory' in the classpath.

将 flink-connector-hbase-2.2_2.11-${flink.version}.jar放在${FLINK_HOME}/lib/下面即可

Caused by: org.apache.flink.table.api.ValidationException: Unable to create a sink for writing table 'default_catalog.default_database.mytable'.

Table options are:

'connector'='hbase-2.2'
'table-name'='_dev_test:mytable'
'zookeeper.quorum'='*****:2181'
	at org.apache.flink.table.factories.FactoryUtil.createTableSink(FactoryUtil.java:171) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.planner.delegation.PlannerBase.getTableSink(PlannerBase.scala:367) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase.translateToRel(PlannerBase.scala:201) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase$$anonfun$1.apply(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase$$anonfun$1.apply(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.Iterator$class.foreach(Iterator.scala:891) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractIterator.foreach(Iterator.scala:1334) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.IterableLike$class.foreach(IterableLike.scala:72) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractIterable.foreach(Iterable.scala:54) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.TraversableLike$class.map(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractTraversable.map(Traversable.scala:104) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.planner.delegation.PlannerBase.translate(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.translate(TableEnvironmentImpl.java:1518) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeInternal(TableEnvironmentImpl.java:740) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeInternal(TableEnvironmentImpl.java:856) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeSql(TableEnvironmentImpl.java:730) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at com.gwm.core.kafka.FlinkKafkaHbase$.main(FlinkKafkaHbase.scala:82) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at com.gwm.core.kafka.FlinkKafkaHbase.main(FlinkKafkaHbase.scala) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_141]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_141]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_141]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_141]
	at org.apache.flink.client.program.PackagedProgram.callMainMethod(PackagedProgram.java:355) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.program.PackagedProgram.invokeInteractiveModeForExecution(PackagedProgram.java:222) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.ClientUtils.executeProgram(ClientUtils.java:114) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.deployment.application.ApplicationDispatcherBootstrap.runApplicationEntryPoint(ApplicationDispatcherBootstrap.java:242) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	... 10 more
Caused by: org.apache.flink.table.api.ValidationException: Cannot discover a connector using option: 'connector'='hbase-2.2'
	at org.apache.flink.table.factories.FactoryUtil.enrichNoMatchingConnectorError(FactoryUtil.java:467) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.factories.FactoryUtil.getDynamicTableFactory(FactoryUtil.java:441) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.factories.FactoryUtil.createTableSink(FactoryUtil.java:167) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.planner.delegation.PlannerBase.getTableSink(PlannerBase.scala:367) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase.translateToRel(PlannerBase.scala:201) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase$$anonfun$1.apply(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.planner.delegation.PlannerBase$$anonfun$1.apply(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.TraversableLike$$anonfun$map$1.apply(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.Iterator$class.foreach(Iterator.scala:891) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractIterator.foreach(Iterator.scala:1334) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.IterableLike$class.foreach(IterableLike.scala:72) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractIterable.foreach(Iterable.scala:54) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.TraversableLike$class.map(TraversableLike.scala:234) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at scala.collection.AbstractTraversable.map(Traversable.scala:104) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.planner.delegation.PlannerBase.translate(PlannerBase.scala:162) ~[flink-table-planner-blink_2.11-1.13.1.jar:1.13.1]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.translate(TableEnvironmentImpl.java:1518) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeInternal(TableEnvironmentImpl.java:740) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeInternal(TableEnvironmentImpl.java:856) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.table.api.internal.TableEnvironmentImpl.executeSql(TableEnvironmentImpl.java:730) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at com.gwm.core.kafka.FlinkKafkaHbase$.main(FlinkKafkaHbase.scala:82) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at com.gwm.core.kafka.FlinkKafkaHbase.main(FlinkKafkaHbase.scala) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_141]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_141]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_141]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_141]
	at org.apache.flink.client.program.PackagedProgram.callMainMethod(PackagedProgram.java:355) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.program.PackagedProgram.invokeInteractiveModeForExecution(PackagedProgram.java:222) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.ClientUtils.executeProgram(ClientUtils.java:114) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	at org.apache.flink.client.deployment.application.ApplicationDispatcherBootstrap.runApplicationEntryPoint(ApplicationDispatcherBootstrap.java:242) ~[flink_sql-1.0-jar-with-dependencies.jar:?]
	... 10 more
Caused by: org.apache.flink.table.api.ValidationException: Could not find any factory for identifier 'hbase-2.2' that implements 'org.apache.flink.table.factories.DynamicTableFactory' in the classpath.


"org.apache.flink.table.api.ValidationException: 无法发现连接器" 是一个Flink Table API的异常,它表示在执行Flink任务时无法找到指定的连接器。连接器是用于连接外部数据源或目标的插件,它们提供了用于读取或写入数据的功能。 出现此异常可能有以下几个原因: 1. 缺少所需的连接器依赖项:这意味着在Flink的运行时环境中缺少必要的连接器库。解决方法是在Flink的类路径中添加正确版本的连接器库。 2. 未正确配置连接器:如果连接器依赖项存在,但无法发现连接器,则可能是由于配置问题。请确保在Flink的配置文件或编程接口中正确设置了连接器的相关属性。 3. 非法的连接器名称:确保指定的连接器名称是有效的。连接器名称通常是特定连接器库的标识符或关键字。 4. 连接器不兼容:该异常也可能是由于连接器与Flink版本不兼容导致的。请检查连接器的兼容性与您正在使用的Flink版本。 为了解决这个问题,您可以执行以下步骤: 1. 确保在Flink的类路径中包含所需的连接器依赖项。 2. 检查连接器的配置是否正确,包括连接器的名称和属性设置。 3. 确保连接器与您使用的Flink版本兼容。 4. 如果可能,请参考Flink文档或在线资源,了解有关特定连接器的配置和用法的更多信息。 总之,当遇到"org.apache.flink.table.api.ValidationException: 无法发现连接器"异常时,需要检查连接器的依赖项、配置、名称和兼容性等方面,以确保正确使用和配置连接器。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值