use protobuf3 with some lib which depends on protobuf2 in Java

给你一囗甜甜゛ 提交于 2019-12-06 10:12:00

问题


I'm using protobuf3 to represent our data, while we need hbase to store the data, it seems like hbase depends on protobuf2.

When i write the following line to create our hbase table

admin.createTable(desc);

then I got an Excepiton: NoClassDefFoundError: com/google/protobuf/LiteralByteString

I've tried using gradle's shadow plugin to relocate com.google.protobuf to shadow.google.com, then it throw a similar message NoClassDefFoundError: shadow/google/protobuf/LiteralByteString.


回答1:


  1. Create a sub-project, and name it 'hbase-wrapper'
  2. Move the dependencies for hbase to the new project
  3. Shadow protobuf in the new project
  4. Add dependency to the sub-project on the main project

Here's some snip code

// part of build.gradle of the sub-project
...
dependencies {
    compile group: 'org.apache.hbase', name: 'hbase-client', version: '1.2.4'
}

shadowJar {
    relocate('com.google.protobuf', 'hbasesaver.google.protobuf')
}

// part of build.gradle for main project
...
compile project(path: ':hbase-wrapper', configuration: 'shadow')


来源:https://stackoverflow.com/questions/41326310/use-protobuf3-with-some-lib-which-depends-on-protobuf2-in-java

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!