CDH HBase脚本运行报错无法加载主类org.apache.hadoop.hbase.util.GetJavaProperty

本文详细描述了如何在使用HBase脚本时遇到关于'org.apache.hadoop.hbase.util.GetJavaProperty'找不到的错误,并提供了针对此问题的解决方案,包括修改脚本中类路径和依赖,确保HBase服务能在所有节点上正常运行。

1.错误描述

在使用hbase或者flume-ng脚本时会报如下错误

错误: 找不到或无法加载主类 org.apache.hadoop.hbase.util.GetJavaProperty

image-20210412140041871

2.错误解决

查找hbase脚本位置

image-20210412140331890

将原有hbase脚本进行备份,然后编辑hbase脚本

image-20210412140856538

在第190行左右的以下代码后

add_to_cp_if_exists "${HBASE_HOME}/hbase-server/target"

添加

    # Needed for GetJavaProperty check below
    add_to_cp_if_exists "${HBASE_HOME}/hbase-server/target/classes"

image-20210412134731838

然后删除200行左右如下代码

#add the hbase jars for each module
for f in $HBASE_HOME/hbase-jars/hbase*.jar; do
    if [[ $f = *sources.jar ]]
  then
    : # Skip sources.jar
  elif [ -f $f ]
  then
    CLASSPATH=${CLASSPATH}:$f;
  fi
done

image-20210412135059762

在320行左右的如下代码后

if [ -n "${HADOOP_IN_PATH}" ] && [ -f "${HADOOP_IN_PATH}" ]; then

添加

  temporary_cp=
  for f in "${HBASE_HOME}"/lib/hbase-server*.jar; do
    if [[ ! "${f}" =~ ^.*\-tests\.jar$ ]]; then
      temporary_cp=":$f"
    fi
  done

并且将

  HADOOP_JAVA_LIBRARY_PATH=$(HADOOP_CLASSPATH="$CLASSPATH" "${HADOOP_IN_PATH}" \

修改为

  HADOOP_JAVA_LIBRARY_PATH=$(HADOOP_CLASSPATH="$CLASSPATH${temporary_cp}" "${HADOOP_IN_PATH}" \

image-20210412135926329

在HBase部署的所有节点上都修改上述脚本后,重启HBase服务

再次查看,脚本已经能够正常运行

image-20210412141550541

3.参考资料

https://blog.youkuaiyun.com/pycrossover/article/details/102627807

https://reviews.apache.org/r/69299/diff/2?expand=1#

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值