java.lang.NoClassDefFoundError: Could not initialize class org.apache.hadoop.hbase.util.ByteStringer

java.lang.NoClassDefFoundError: Could not initialize class org.apache.hadoop.hbase.util.ByteStringer
java.lang.NoClassDefFoundError: com/google/protobuf/LiteralByteString

在与HBase数据库交互的时候,可能会出现上述两种错误。查询Maven依赖,会发现出现了Jar包冲突。

 

解决办法:

(试错)

看到这个错误,我的第一反正就是加入没有找到的jar。于是一顿操作,加入了如下依赖

<dependency>
    <groupId>com.google.protobuf</groupId>
    <artifactId>protobuf-java</artifactId>
    <version>3.0.0</version>
</dependency>

jar包导入了,但是还是报错。当时意识到可能是版本不对。于是又是一通找。

 

(解决)

我的本地HBase的版本号为1.2.0-cdh2.7.0。对于1.2.X版本的Hbase而言,他依赖的是2.5.0的版本,所以上述版本号要变化。不仅如此,jar冲突的来源是因为我还使用Mysql的jar,8.0.20版本的mysql使用的是3.X.X版本的protobuf,如不想使用上述办法,还可以将mysql的jdbc版本改为5.X.X版本的,如5.1.46

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java.lang.NoClassDefFoundError: Could not initialize class异常通常是由于类的静态初始化块或静态变量的初始化过程中发生了异常导致的。这个异常表示在类加载过程中,虚拟机无法找到或初始化指定的类。 对于引用中的异常"java.lang.NoClassDefFoundError: Could not initialize class xxx",其中的"xxx"是指具体的类名。这个异常的原因可能是以下几种情况之一: 1. 缺少相关的依赖库或jar包。 2. 类的静态初始化块或静态变量的初始化过程中发生了异常。 3. 类的初始化过程中发生了其他异常,例如访问权限问题或反射异常等。 解决这个异常的方法可以尝试以下几种方式: 1. 检查相关的依赖库或jar包是否存在,并确保它们的版本和路径正确。 2. 检查类的静态初始化块或静态变量的初始化过程中是否有异常抛出,并修复这些异常。 3. 检查类的初始化过程中是否有其他异常抛出,并修复这些异常。 4. 检查类的访问权限是否正确,并确保没有其他限制导致类无法被初始化。 5. 如果使用了反射相关的代码,检查反射相关的异常,并修复这些异常。 以下是一个示例代码,演示了如何处理java.lang.NoClassDefFoundError异常: ```java try { // 尝试初始化类 Class.forName("org.mockito.Mockito"); } catch (ClassNotFoundException e) { // 类未找到异常 e.printStackTrace(); } catch (ExceptionInInitializerError e) { // 类的静态初始化过程中发生了异常 e.printStackTrace(); } catch (Throwable t) { // 其他异常 t.printStackTrace(); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值