• phoenix创建表失败:phoenixIOException: Max attempts exceeded


    下面的问题,搞了1天才解决,太坑了,在这里记录一下。

    问题现像:执行命令后,1分钟没有返回, 然后报下面的错,偶尔会出现以下不同的报错信息。

    jdbc:phoenix:10.0.xx.1:2181>  create  table  IF  NOT  EXISTS  test.Person1  (IDCardNum  INTEGER  not  null  primary  key,  Name  varchar(20),Age  INTEGER)  COMPRESSION  =  'SNAPPY',BLOOMFILTER  =  'ROW';
    Error:  Max  attempts  exceeded  (state=08000,code=101)
    org.apache.phoenix.exception.PhoenixIOException:  Max  attempts  exceeded
    at  org.apache.phoenix.util.ServerUtil.parseServerException(ServerUtil.java:138)
    at  org.apache.phoenix.query.ConnectionQueryServicesImpl.ensureTableCreated(ConnectionQueryServicesImpl.java:1204)
    at  org.apache.phoenix.query.ConnectionQueryServicesImpl.createTable(ConnectionQueryServicesImpl.java:1501)
    at  org.apache.phoenix.schema.MetaDataClient.createTableInternal(MetaDataClient.java:2721)
    at  org.apache.phoenix.schema.MetaDataClient.createTable(MetaDataClient.java:1114)
    at  org.apache.phoenix.compile.CreateTableCompiler$1.execute(CreateTableCompiler.java:192)
    at  org.apache.phoenix.jdbc.PhoenixStatement$2.call(PhoenixStatement.java:408)
    at  org.apache.phoenix.jdbc.PhoenixStatement$2.call(PhoenixStatement.java:391)
    at  org.apache.phoenix.call.CallRunner.run(CallRunner.java:53)
    at  org.apache.phoenix.jdbc.PhoenixStatement.executeMutation(PhoenixStatement.java:390)
    at  org.apache.phoenix.jdbc.PhoenixStatement.executeMutation(PhoenixStatement.java:378)
    at  org.apache.phoenix.jdbc.PhoenixStatement.execute(PhoenixStatement.java:1825)
    at  sqlline.Commands.execute(Commands.java:822)
    at  sqlline.Commands.sql(Commands.java:732)
    at  sqlline.SqlLine.dispatch(SqlLine.java:813)
    at  sqlline.SqlLine.begin(SqlLine.java:686)
    at  sqlline.SqlLine.start(SqlLine.java:398)
    at  sqlline.SqlLine.main(SqlLine.java:291)
    Caused  by:  org.apache.hadoop.hbase.client.RetriesExhaustedException:  Max  attempts  exceeded
    at  org.apache.hadoop.hbase.master.assignment.AssignProcedure.startTransition(AssignProcedure.java:180)
    at  org.apache.hadoop.hbase.master.assignment.RegionTransitionProcedure.execute(RegionTransitionProcedure.java:295)
    at  org.apache.hadoop.hbase.master.assignment.RegionTransitionProcedure.execute(RegionTransitionProcedure.java:85)
    at  org.apache.hadoop.hbase.procedure2.Procedure.doExecute(Procedure.java:845)
    at  org.apache.hadoop.hbase.procedure2.ProcedureExecutor.execProcedure(ProcedureExecutor.java:1453)
    at  org.apache.hadoop.hbase.procedure2.ProcedureExecutor.executeProcedure(ProcedureExecutor.java:1221)
    at  org.apache.hadoop.hbase.procedure2.ProcedureExecutor.access$800(ProcedureExecutor.java:75)
    at  org.apache.hadoop.hbase.procedure2.ProcedureExecutor$WorkerThread.run(ProcedureExecutor.java:1741)

    jdbc:phoenix:10.0.xx.1:2181>  create  table  IF  NOT  EXISTS  test.Person1  (IDCardNum  INTEGER  not  null  primary  key,  Name  varchar(20),Age  INTEGER)  COMPRESSION  =  'SNAPPY',BLOOMFILTER  =  'ROW';
    Error:  ERROR  1102  (XCL02):  Cannot  get  all  table  regions.  (state=XCL02,code=1102)
    java.sql.SQLException:  ERROR  1102  (XCL02):  Cannot  get  all  table  regions.
    at  org.apache.phoenix.exception.SQLExceptionCode$Factory$1.newException(SQLExceptionCode.java)

    .....................

    问题原因:

      因为该服务器用的是虚拟机,运维人员设置该虚拟机的内存为动态分配,内存不够所以产生问题。

    改成下面的固定内存就好了:

  • 相关阅读:
    设计原则
    最小路径和--p64--动态规划
    ssm实现数据库关键信息的动态加载
    最大二叉树--p654--递归构造
    城市天际线--p807
    长url转短url--p535
    从中序与后序遍历中构造二叉树-p106--数组,二叉树遍历
    n皇后问题--p52--回溯
    Markdown(editormd)语法解析成HTML
    NFA的实现
  • 原文地址:https://www.cnblogs.com/caoweixiong/p/11747292.html
Copyright © 2020-2023  润新知