Последняя зависимость MRunit в репозитории cloudera

Мне не удалось найти последнюю версию mrunit(1.1.0) в репозитории Cloudera. Доступен 0.8.0-incubating. Ниже мой pom:

<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.ma.hadoop</groupId>
    <artifactId>MapReduce</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <properties>
        <hadoop.version>2.3.0-cdh5.1.2</hadoop.version>
        <hive.version>0.12.0-cdh5.1.2</hive.version>
        <mrunit.version>0.8.0-incubating</mrunit.version>
    </properties>
    <dependencies>
        <!-- For unit testing -->
        <dependency>
            <groupId>org.apache.mrunit</groupId>
            <artifactId>mrunit</artifactId>
            <version>${mrunit.version}</version>
        </dependency>
        <!-- This is sufficient for all -->
        <dependency>
            <groupId>org.apache.hadoop</groupId>
            <artifactId>hadoop-client</artifactId>
            <version>${hadoop.version}</version>
        </dependency>
    </dependencies>
    <build>
        <finalName>Mapred</finalName>
        <pluginManagement>
            <plugins>
                <plugin>
                    <groupId>org.codehaus.mojo</groupId>
                    <artifactId>exec-maven-plugin</artifactId>
                    <version>1.2.1</version>
                </plugin>
            </plugins>
        </pluginManagement>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.1</version>
                <configuration>
                    <source>${jdk.version}</source>
                    <target>${jdk.version}</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.4</version>
                <configuration>
                    <outputDirectory>${basedir}</outputDirectory>
                </configuration>
            </plugin>
        </plugins>
    </build>
    <repositories>
        <repository>
            <id>maven-hadoop</id>
            <name>Hadoop Releases</name>
            <url>https://repository.cloudera.com/content/repositories/releases/</url>
        </repository>
        <repository>
            <id>cloudera-repos</id>
            <name>Cloudera Repos</name>
            <url>https://repository.cloudera.com/artifactory/cloudera-repos/</url>
        </repository>
    </repositories>
</project>

если я изменю версию на 1.1.0, eclipse выдаст артефакт, не найденный в зависимости mrunit в файле pom.

Я попытался добавить репозиторий Apache

<id>central</id>
<url>http://repo1.maven.org/maven2/</url>
<repository>

Eclipse загружает банку в .m2, но артефакт все равно не найден. Вызов модульного теста не будет компилироваться. Может кто-нибудь помочь, как безопасно использовать последнюю версию mrunit с репозиторием cloudera.

Спасибо, Амит


person Dutta    schedule 17.10.2014    source источник
comment
у меня тоже такой же статус   -  person brucenan    schedule 11.12.2014
comment
было то же самое в идее, и ответ бруценана исправил мне эту проблему, вы должны принять его ответ :)   -  person AdrieanKhisbe    schedule 22.01.2015


Ответы (1)


В вашем объявлении mrunitdependancy:

<dependency>
   <groupId>org.apache.mrunit</groupId>
   <artifactId>mrunit</artifactId>
   <version>${mrunit.version}</version>
</dependency>

Вы должны добавить <classifier>hadoop2</classifier>, чтобы уточнить, какую версию hadoop вы хотите использовать, значение классификатора — hadoop1 или hadoop2.

Поэтому вам нужно изменить pom.xmldependancy на это, так как вы используете Hadoop 2.X:

<dependency>
    <groupId>org.apache.mrunit</groupId>
    <artifactId>mrunit</artifactId>
    <version>${mrunit.version}</version>
    <classifier>hadoop2</classifier>
</dependency>
person brucenan    schedule 11.12.2014