gpt4 book ai didi

java - Dropwizard 和 hive-jdbc 之间的不兼容

转载 作者:可可西里 更新时间:2023-11-01 16:38:58 27 4
gpt4 key购买 nike

我正在尝试使用 Dropwizard 创建一个 WS REST,以获取查询的 Hive 结果并以 XML 格式呈现。每个单独的部分都可以毫无错误地完成。

当我加入所有内容时,我发现 Dropwizard 和 hive-jdbc 之间不兼容。显然 hive-jdbc 有 jersey 1 作为依赖项,而 Dropwizard 有 jersey 2。

我不确定这是否是问题所在。我试图排除 pom.xml 中的依赖项,但没有解决。

我试图制作一个应用程序,只是将 hive-jdbc 作为依赖项放在 pom.xml 文件中,而不使用或导入代码的任何部分,但错误仍然发生。

POM.XML

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">

<prerequisites>
<maven>3.0.0</maven>
</prerequisites>

<modelVersion>4.0.0</modelVersion>
<groupId>test</groupId>
<artifactId>ws-test</artifactId>
<version>1.0.0</version>
<name>ws-test</name>

<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<dropwizard.version>1.0.5</dropwizard.version>
<mainClass>test.TestApp</mainClass>
</properties>

<dependencyManagement>
<dependencies>
<dependency>
<groupId>io.dropwizard</groupId>
<artifactId>dropwizard-bom</artifactId>
<version>${dropwizard.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>

<dependencies>
<dependency>
<groupId>io.dropwizard</groupId>
<artifactId>dropwizard-core</artifactId>
</dependency>
<dependency>
<groupId>io.dropwizard</groupId>
<artifactId>dropwizard-forms</artifactId>
</dependency>
<dependency>
<groupId>org.apache.hive</groupId>
<artifactId>hive-jdbc</artifactId>
<version>1.1.0</version>
</dependency>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-core</artifactId>
<version>1.2.1</version>
</dependency>
</dependencies>

<build>
<plugins>
<plugin>
<artifactId>maven-shade-plugin</artifactId>
<version>2.4.1</version>
<configuration>
<createDependencyReducedPom>true</createDependencyReducedPom>
<transformers>
<transformer
implementation="org.apache.maven.plugins.shade.resource.ServicesResourceTransformer" />
<transformer
implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>${mainClass}</mainClass>
</transformer>
</transformers>
<!-- exclude signed Manifests -->
<filters>
<filter>
<artifact>*:*</artifact>
<excludes>
<exclude>META-INF/*.SF</exclude>
<exclude>META-INF/*.DSA</exclude>
<exclude>META-INF/*.RSA</exclude>
</excludes>
</filter>
</filters>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<artifactId>maven-jar-plugin</artifactId>
<version>2.6</version>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<mainClass>${mainClass}</mainClass>
<addDefaultImplementationEntries>true</addDefaultImplementationEntries>
</manifest>
</archive>
</configuration>
</plugin>
</plugins>
</build>
</project>

TestApp.java

package test;

import io.dropwizard.Application;
import io.dropwizard.forms.MultiPartBundle;
import io.dropwizard.setup.Bootstrap;
import io.dropwizard.setup.Environment;

public class TestApp extends Application<TestConf> {

public static void main(String[] args){
try {
new TestApp().run(args);
}
catch(Exception e) {
e.printStackTrace();
}
}

@Override
public String getName() {
return "ID Generator Server";
}

@Override
public void initialize(final Bootstrap<TestConf> bootstrap) {
bootstrap.addBundle(new MultiPartBundle());
}

@Override
public void run(final TestConf configuration,
final Environment environment) {
final TestRes resource = new TestRes(
configuration.getTemplate(),
configuration.getDefaultName()
);
environment.jersey().register(resource);
}

}

TestConf.java

package test;

import io.dropwizard.Configuration;
import com.fasterxml.jackson.annotation.JsonProperty;
import org.hibernate.validator.constraints.*;

public class TestConf extends Configuration {

@NotEmpty
private String template;

@NotEmpty
private String defaultName = "MarineTraffic";

@JsonProperty
public String getTemplate() {
return template;
}

@JsonProperty
public void setTemplate(String template) {
this.template = template;
}

@JsonProperty
public String getDefaultName() {
return defaultName;
}

@JsonProperty
public void setDefaultName(String name) {
this.defaultName = name;
}
}

TestRes.java

package test;

import javax.ws.rs.GET;
import javax.ws.rs.Path;
import javax.ws.rs.Produces;
import javax.ws.rs.core.MediaType;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

@Path("/hive")
public class TestRes {

protected final static Logger LOGGER = LoggerFactory.getLogger(TestRes.class);
protected final static String HEADER = "GroupService::";

public TestRes(String template, String defaultName) {
LOGGER.info(HEADER + "init: PostConstruct");
}

@GET
@Path("/test")
@Produces(MediaType.TEXT_PLAIN)
public String getNewID() {

return "works";
}
}

我得到的错误是这样的:

WARN  [2017-08-10 21:50:21,444] org.glassfish.jersey.internal.Errors: The following warnings have been detected: WARNING: Unknown HK2 failure detected:
MultiException stack 1 of 2
java.lang.NullPointerException
at com.sun.jersey.core.provider.jaxb.AbstractJAXBProvider.setConfiguration(AbstractJAXBProvider.java:107)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
...
at test.TestApp.main(TestApp.java:12)
MultiException stack 2 of 2
java.lang.IllegalStateException: Unable to perform operation: method inject on com.sun.jersey.core.impl.provider.entity.XMLRootElementProvider$App
at org.jvnet.hk2.internal.ClazzCreator.create(ClazzCreator.java:392)
at org.jvnet.hk2.internal.SystemDescriptor.create(SystemDescriptor.java:471)
...

WARNING: Unknown HK2 failure detected:
MultiException stack 1 of 3
java.lang.NullPointerException
at com.sun.jersey.core.provider.jaxb.AbstractJAXBProvider.setConfiguration(AbstractJAXBProvider.java:107)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
...
at test.TestApp.main(TestApp.java:12)
MultiException stack 2 of 3
java.lang.IllegalStateException: Unable to perform operation: method inject on com.sun.jersey.core.impl.provider.entity.XMLRootElementProvider$App
at org.jvnet.hk2.internal.ClazzCreator.create(ClazzCreator.java:392)
at org.jvnet.hk2.internal.SystemDescriptor.create(SystemDescriptor.java:471)
...
at test.TestApp.main(TestApp.java:12)
MultiException stack 3 of 3
java.lang.IllegalStateException: Unable to perform operation: create on org.glassfish.jersey.message.internal.MessageBodyFactory
at org.jvnet.hk2.internal.ClazzCreator.create(ClazzCreator.java:386)
at org.jvnet.hk2.internal.SystemDescriptor.create(SystemDescriptor.java:471)
...

我发现一些用户遇到了类似的错误(如 dropwizard and hive/hiverunner integration with mavenhttp://thread.gmane.org/gmane.comp.java.dropwizard.devel/461 )

这是导致错误的问题(在 Jersey 中不兼容)吗?有谁知道怎么解决吗?

最佳答案

是的,它的 jersey 冲突问题,从 hive-jdbc 和 hadoop-core 中排除 jersey 1 依赖项 (com.sun.jersey)。已经运行了您的测试应用程序并且它在以下排除项下工作。

 <dependency>
<groupId>org.apache.hive</groupId>
<artifactId>hive-jdbc</artifactId>
<version>1.1.0</version>
<exclusions>
<exclusion>
<groupId>com.sun.jersey</groupId>
<artifactId>*</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.hadoop</groupId>
<artifactId>hadoop-core</artifactId>
<version>1.2.1</version>
<exclusions>
<exclusion>
<groupId>com.sun.jersey</groupId>
<artifactId>*</artifactId>
</exclusion>
</exclusions>
</dependency>

关于java - Dropwizard 和 hive-jdbc 之间的不兼容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45624062/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com