错误
在Kerberized环境中运行查询时,使用Hive中的HBase存储处理程序接收此错误。关于HBase 1.5
Caused by: org.apache.hadoop.hbase.exceptions.UnknownProtocolException: org.apache.hadoop.hbase.exceptions.UnknownProtocolException:
No registered coprocessor service found for name AuthenticationService in region hbase:meta,,1
at org.apache.hadoop.hbase.regionserver.HRegion.execService(HRegion.java:8499)
at org.apache.hadoop.hbase.regionserver.RSRpcServices.execServiceOnRegion(RSRpcServices.java:2282)
at org.apache.hadoop.hbase.regionserver.RSRpcServices.execService(RSRpcServices.java:2264)
at org.apache.hadoop.hbase.protobuf.generated.ClientProtos$ClientService$2.callBlockingMethod(ClientProtos.java:36808)
at org.apache.hadoop.hbase.ipc.RpcServer.call(RpcServer.java:2399)
at org.apache.hadoop.hbase.ipc.CallRunner.run(CallRunner.java:124)
at org.apache.hadoop.hbase.ipc.RpcExecutor$Handler.run(RpcExecutor.java:311)
at org.apache.hadoop.hbase.ipc.RpcExecutor$Handler.run(RpcExecutor.java:291)
重要的部分是:
没有注册的协处理器服务在区域
hbase:meta,,1
中为名称AuthenticationService
找到
我读了一些书,了解到AuthenticationService
是由TokenProvider协处理器提供的。
发布于 2020-03-16 19:17:48
在hbase-site.xml
中,确保配置了这些选项
hadoop.security.authentication
hbase.coprocessor.master.classes
hbase.coprocessor.region.classes
确保按以下方式配置值:
<property>
<name>hadoop.security.authentication</name>
<value>kerberos</value>
</property>
<property>
<name>hbase.coprocessor.master.classes</name>
<value>org.apache.hadoop.hbase.security.access.AccessController</value>
</property>
<property>
<name>hbase.coprocessor.region.classes</name>
<value>org.apache.hadoop.hbase.security.token.TokenProvider,org.apache.hadoop.hbase.security.access.AccessController</value>
</property>
注意事项:在HBase的旧版本中使用了设置hbase.coprocessor.regionserver.classes
,确保使用的是正确的;hbase.coprocessor.region.classes
https://stackoverflow.com/questions/60711995
复制相似问题