首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >com/google/api/gax/retrying/ExceptionRetryAlgorithm : BigQuery: java.lang.NoClassDefFoundError

com/google/api/gax/retrying/ExceptionRetryAlgorithm : BigQuery: java.lang.NoClassDefFoundError
EN

Stack Overflow用户
提问于 2020-04-06 16:57:54
回答 1查看 482关注 0票数 0

我正在做一个Google-Dataflow java项目。我试图在管道的初始化过程中创建和更新BigQuery表,所以为了开始,我尝试以这种方式实例化BigQuery Java客户端:

代码语言:javascript
复制
 BigQuery bigquery = BigQueryOptions.getDefaultInstance().getService();

在运行时,它会给我带来以下异常:

代码语言:javascript
复制
Exception in thread "main" java.lang.NoClassDefFoundError: com/google/api/gax/retrying/ExceptionRetryAlgorithm
    at java.lang.ClassLoader.defineClass1(Native Method)
    at java.lang.ClassLoader.defineClass(ClassLoader.java:756)
    at java.security.SecureClassLoader.defineClass(SecureClassLoader.java:142)
    at java.net.URLClassLoader.defineClass(URLClassLoader.java:468)
    at java.net.URLClassLoader.access$100(URLClassLoader.java:74)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:369)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:363)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:362)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:352)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
    at com.google.cloud.BaseService.<clinit>(BaseService.java:48)
    at com.google.cloud.bigquery.BigQueryOptions$DefaultBigQueryFactory.create(BigQueryOptions.java:46)
    at com.google.cloud.bigquery.BigQueryOptions$DefaultBigQueryFactory.create(BigQueryOptions.java:40)
    at com.google.cloud.ServiceOptions.getService(ServiceOptions.java:426)
    at com.mydomain.Analysis.main(Analysis.java:359)

Caused by: java.lang.ClassNotFoundException: com.google.api.gax.retrying.ExceptionRetryAlgorithm
    at java.net.URLClassLoader.findClass(URLClassLoader.java:382)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:418)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:352)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:351)
    ... 17 more

这是我的pom.xml:

代码语言:javascript
复制
<properties>
    <beam.version>2.19.0</beam.version>
</properties>


<dependencies>

    <!-- https://mvnrepository.com/artifact/org.apache.commons/commons-collections4 -->
    <dependency>
        <groupId>org.apache.commons</groupId>
        <artifactId>commons-collections4</artifactId>
        <version>4.0</version>
    </dependency>

    <dependency>
        <groupId>com.google.cloud</groupId>
        <artifactId>google-cloud-bigquery</artifactId>
        <version>1.110.0</version>
    </dependency>


    <!-- Beam -->
    <dependency>
        <groupId>org.apache.beam</groupId>
        <artifactId>beam-sdks-java-core</artifactId>
        <version>${beam.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.beam</groupId>
        <artifactId>beam-sdks-java-io-google-cloud-platform</artifactId>
        <version>${beam.version}</version>
        <exclusions>
            <exclusion>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
            </exclusion>
        </exclusions>
    </dependency>
    <dependency>
        <groupId>org.apache.beam</groupId>
        <artifactId>beam-sdks-java-extensions-google-cloud-platform-core</artifactId>
        <version>${beam.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.beam</groupId>
        <artifactId>beam-runners-google-cloud-dataflow-java</artifactId>
        <version>${beam.version}</version>
    </dependency>
    <dependency>
        <groupId>org.apache.beam</groupId>
        <artifactId>beam-sdks-java-io-jdbc</artifactId>
        <version>${beam.version}</version>
    </dependency>
</dependencies>

我遗漏了什么?

EN

回答 1

Stack Overflow用户

发布于 2020-04-07 04:09:55

从错误中看,似乎缺少包含com.google.api.gax.retrying.ExceptionRetryAlgorithm.java类的某个jar。

通过快速的google搜索,我将下面的依赖添加到pom中。这个gax jar包含ExceptionRetryAlgorithm类。

代码语言:javascript
复制
    <dependency>
        <groupId>com.google.api</groupId>
        <artifactId>gax</artifactId>
        <version>0.14.0</version>
    </dependency>

希望添加上述依赖到您的pom,应该可以解决这个问题。

你好,舒瓦迪普

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61056188

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档