HBase启动报错:Operation category READ is not supported in state standby

今天配置HBase的HA,启动的时候,Master1节点的HMaster启动10秒左右就自动挂掉,Master2的备份节点的web界面也访问不了,查看日志报了如下错误:

2020-04-24 16:51:45,573 FATAL [Master1:16000.activeMasterManager] master.HMaster: Unhandled exception. Starting shutdown.
org.apache.hadoop.ipc.RemoteException(org.apache.hadoop.ipc.StandbyException): Operation category READ is not supported in state standby
    at org.apache.hadoop.hdfs.server.namenode.ha.StandbyState.checkOperation(StandbyState.java:87)
    at org.apache.hadoop.hdfs.server.namenode.NameNode$NameNodeHAContext.checkOperation(NameNode.java:1802)
    at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.checkOperation(FSNamesystem.java:1321)
    at org.apache.hadoop.hdfs.server.namenode.FSNamesystem.getFileInfo(FSNamesystem.java:3829)
    at org.apache.hadoop.hdfs.server.namenode.NameNodeRpcServer.getFileInfo(NameNodeRpcServer.java:1012)
    at org.apache.hadoop.hdfs.protocolPB.ClientNamenodeProtocolServerSideTranslatorPB.getFileInfo(ClientNamenodeProtocolServerSideTranslatorPB.java:855)
    at org.apache.hadoop.hdfs.protocol.proto.ClientNamenodeProtocolProtos$ClientNamenodeProtocol$2.callBlockingMethod(ClientNamenodeProtocolProtos.java)
    at org.apache.hadoop.ipc.ProtobufRpcEngine$Server$ProtoBufRpcInvoker.call(ProtobufRpcEngine.java:616)
    at org.apache.hadoop.ipc.RPC$Server.call(RPC.java:982)
    at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:2217)
    at org.apache.hadoop.ipc.Server$Handler$1.run(Server.java:2213)
    at java.security.AccessController.doPrivileged(Native Method)
    at javax.security.auth.Subject.doAs(Subject.java:422)
    at org.apache.hadoop.security.UserGroupInformation.doAs(UserGroupInformation.java:1762)
    at org.apache.hadoop.ipc.Server$Handler.run(Server.java:2211) 

去网上搜了原因,有的说是namenode的两个节点都变成standby了,让一个成为active就可以了。

我去查看了自己的namenode,一个standby一个active正常,所以不是这里的原因。

我的Master1节点是standby状态,Master2是active,我是在Master1上启动的HBase,我想是不是因为没在active节点上启动的原因。于是我把Master2的namenode kill掉,让Master1的namenode自动变成active,然后在Master1单点启动HMaster,成功!web页面访问正常。

总结一个结论:HBaseHA的群起必须在namenode为active的节点上

ps:这就比较恶心了,脚本启动谁知道active在哪?不知道是我的理解有误?

你可能感兴趣的:(HBase)