sql:
tEnv.executeSql("DROP TABLE IF EXISTS ywb_source");
tEnv.executeSql(
"CREATE TABLE ywb_source (\n" +
" rowkey STRING,\n" +
" info1 ROW<name STRING>,\n" +
" info2 ROW<age STRING>,\n" +
" PRIMARY KEY (rowkey) NOT ENFORCED\n" +
") WITH (\n" +
" 'connector' = 'pa-hbase',\n" +
" 'table-name' = 'ywb_t1',\n" +
" 'zookeeper.quorum' = '10.100.2.191:2181'\n" +
")");
// 查询
tEnv.executeSql("desc ywb_source").print();
tEnv.executeSql("SELECT * FROM ywb_source").print();
报错信息:
Caused by: java.io.IOException: org.apache.flink.hbase.shaded.org.apache.zookeeper.KeeperException$NoNodeException: KeeperErrorCode = NoNode for /hbase
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.client.ConnectionImplementation.get(ConnectionImplementation.java:2081)
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.client.ConnectionImplementation.locateMeta(ConnectionImplementation.java:814)
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.client.ConnectionImplementation.locateRegion(ConnectionImplementation.java:781)
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.client.RpcRetryingCallerWithReadReplicas.getRegionLocations(RpcRetryingCallerWithReadReplicas.java:326)
... 38 more
Caused by: org.apache.flink.hbase.shaded.org.apache.zookeeper.KeeperException$NoNodeException: KeeperErrorCode = NoNode for /hbase
at org.apache.flink.hbase.shaded.org.apache.zookeeper.KeeperException.create(KeeperException.java:114)
at org.apache.flink.hbase.shaded.org.apache.zookeeper.KeeperException.create(KeeperException.java:54)
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.zookeeper.ReadOnlyZKClient$ZKTask$1.exec(ReadOnlyZKClient.java:177)
at org.apache.flink.hbase.shaded.org.apache.hadoop.hbase.zookeeper.ReadOnlyZKClient.run(ReadOnlyZKClient.java:342)
... 1 more
分析:
根据报错信息显示,在zk中没有配置hbase节点,或者说hbase在zk中配置的节点名称不是/hbase,所以先查看habse-site.xml文件,结果如下:
<property>
<name>zookeeper.znode.parent</name>
<value>/hbase-unsecure</value>
</property>
由此可知,hbase在zk中配置的节点名称是/hbase-unsecure,将这个配置填入到hbase连接器中,错误解决。
更正建表sql:
tEnv.executeSql(
"CREATE TABLE ywb_source (\n" +
" rowkey STRING,\n" +
" info1 ROW<name STRING>,\n" +
" info2 ROW<age STRING>,\n" +
" PRIMARY KEY (rowkey) NOT ENFORCED\n" +
") WITH (\n" +
" 'connector' = 'pa-hbase',\n" +
" 'table-name' = 'ywb_t1',\n" +
" 'zookeeper.quorum' = '10.100.2.191:2181',\n" +
// 新增连接器配置
" 'zookeeper.znode.parent' = '/hbase-unsecure'" +
")");