热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

phoenix开启schema对应hbase中的namespace

开启schema与namespace的对应关系如果使用了hbase中的自定义namespace,不仅仅使用default,那么在phoenix中与之对应的是schema的概念,但是

开启schema与namespace的对应关系

如果使用了hbase中的自定义namespace,不仅仅使用default,那么在phoenix中与之对应的是schema的概念,但是默认并没有开启,需要在hbase-site.xml中增加以下配置项:


phoenix.schema.isNamespaceMappingEnabled
true


phoenix.schema.mapSystemTablesToNamespace
true

客户端使用schema

我们在java 客户端通过phoenix 的jar包进行访问phoenix时,如果使用的是通过phoenix自带的jar包的话,会不断的报错。pom.xml配置如下:


org.apache.phoenix
phoenix-core
4.7.0-HBase-1.1

因此,必须和服务端(hbase下的jar包)版本一致,正确做法是拷贝服务端jar包,配置如下:


org.apache.phoenix
phoenix-core
4.7.0.2.5.0.0-1245
system
${project.basedir}/lib/phoenix-server.jar

创建view对应到已经存在的hbase表报错

目前发现如果开启namespace和schema的对应关系后,创建view对应到已经存在的hbase表报错:

Error: ERROR 505 (42000): Table is read only. (state=42000,code=505)
org.apache.phoenix.schema.ReadOnlyTableException: ERROR 505 (42000): Table is read only.
at org.apache.phoenix.query.ConnectionQueryServicesImpl.ensureTableCreated(ConnectionQueryServicesImpl.java:1032)
at org.apache.phoenix.query.ConnectionQueryServicesImpl.createTable(ConnectionQueryServicesImpl.java:1415)
at org.apache.phoenix.schema.MetaDataClient.createTableInternal(MetaDataClient.java:2180)
at org.apache.phoenix.schema.MetaDataClient.createTable(MetaDataClient.java:865)
at org.apache.phoenix.compile.CreateTableCompiler$2.execute(CreateTableCompiler.java:194)
at org.apache.phoenix.jdbc.PhoenixStatement$2.call(PhoenixStatement.java:343)
at org.apache.phoenix.jdbc.PhoenixStatement$2.call(PhoenixStatement.java:331)
at org.apache.phoenix.call.CallRunner.run(CallRunner.java:53)
at org.apache.phoenix.jdbc.PhoenixStatement.executeMutation(PhoenixStatement.java:329)
at org.apache.phoenix.jdbc.PhoenixStatement.execute(PhoenixStatement.java:1440)
at sqlline.Commands.execute(Commands.java:822)
at sqlline.Commands.sql(Commands.java:732)
at sqlline.SqlLine.dispatch(SqlLine.java:808)
at sqlline.SqlLine.begin(SqlLine.java:681)
at sqlline.SqlLine.start(SqlLine.java:398)
at sqlline.SqlLine.main(SqlLine.java:292)

起初,我以为是哪里配置有问题,经过调试确实在创建view后又进行了一次create view操作,导致了namespace.table转换不成hbase中需要的namespace:table格式。所以报以上错误,应该是phoenix的一个bug。
各种搜索后,找到以下网页,可以佐证我的想法:
最有含金量的参考
https://community.hortonworks.com/questions/65172/views-on-existing-hbase-namespace-tables.html?childToView=65180#answer-65180
https://community.hortonworks.com/questions/97154/map-phoenix-view-to-existing-hbase-namespace-table.html
https://stackoverflow.com/questions/39974877/create-view-in-apache-phoenix-error-505

对于开启权限管理的hbase,设置访问phoenix的用户权限

需要在hbase中做如下处理

grant 'user','C' 创建权限
grant 'user','XCRW','@SYSTEM'

推荐阅读
author-avatar
wwwmanbj_796_897
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有