開啟schema與namespace的對(duì)應(yīng)關(guān)系
如果使用了hbase中的自定義namespace,不僅僅使用default,那么在phoenix中與之對(duì)應(yīng)的是schema的概念搀庶,但是默認(rèn)并沒有開啟拐纱,需要在hbase-site.xml中增加以下配置項(xiàng):
<property>
<name>phoenix.schema.isNamespaceMappingEnabled</name>
<value>true</value>
</property>
<property>
<name>phoenix.schema.mapSystemTablesToNamespace</name>
<value>true</value>
</property>
客戶端使用schema
我們?cè)趈ava 客戶端通過phoenix 的jar包進(jìn)行訪問phoenix時(shí),如果使用的是通過phoenix自帶的jar包的話哥倔,會(huì)不斷的報(bào)錯(cuò)秸架。pom.xml配置如下:
<dependency>
<groupId>org.apache.phoenix</groupId>
<artifactId>phoenix-core</artifactId>
<version>4.7.0-HBase-1.1</version>
</dependency>
因此,必須和服務(wù)端(hbase下的jar包)版本一致未斑,正確做法是拷貝服務(wù)端jar包咕宿,配置如下:
<dependency>
<groupId>org.apache.phoenix</groupId>
<artifactId>phoenix-core</artifactId>
<version>4.7.0.2.5.0.0-1245</version>
<scope>system</scope>
<systemPath>${project.basedir}/lib/phoenix-server.jar</systemPath>
</dependency>
創(chuàng)建view對(duì)應(yīng)到已經(jīng)存在的hbase表報(bào)錯(cuò)
目前發(fā)現(xiàn)如果開啟namespace和schema的對(duì)應(yīng)關(guān)系后,創(chuàng)建view對(duì)應(yīng)到已經(jīng)存在的hbase表報(bào)錯(cuò):
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)
起初蜡秽,我以為是哪里配置有問題府阀,經(jīng)過調(diào)試確實(shí)在創(chuàng)建view后又進(jìn)行了一次create view操作,導(dǎo)致了namespace.table轉(zhuǎn)換不成hbase中需要的namespace:table格式芽突。所以報(bào)以上錯(cuò)誤试浙,應(yīng)該是phoenix的一個(gè)bug。
各種搜索后寞蚌,找到以下網(wǎng)頁(yè)田巴,可以佐證我的想法:
最有含金量的參考
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
對(duì)于開啟權(quán)限管理的hbase,設(shè)置訪問phoenix的用戶權(quán)限
需要在hbase中做如下處理
grant 'user','C' 創(chuàng)建權(quán)限
grant 'user','XCRW','@SYSTEM'