cloud9中MongoClient的NoClassDefFoundError

时间:2018-03-02 18:37:32

标签: java maven apache-spark cloud9

我正在使用maven创建一个可以启动的jar。

所以我这样做:mvn clean install我拿到了罐子。

当我这样做时:java -jar target/ProjetMRS-0.0.1-SNAPSHOT.jar我收到以下错误:

Exception in thread "main" java.lang.NoClassDefFoundError: com/mongodb/MongoClient                                                       
        at iut.nantes.Projet.service.ServicePersonne.<init>(ServicePersonne.java:21)                                                  
        at iut.nantes.projetMRS.Api.<clinit>(Api.java:21)                                                                                
Caused by: java.lang.ClassNotFoundException: com.mongodb.MongoClient                                                                     
        at java.net.URLClassLoader.findClass(URLClassLoader.java:381)                                                                    
        at java.lang.ClassLoader.loadClass(ClassLoader.java:424)                                                                         
        at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:338)                                                                 
        at java.lang.ClassLoader.loadClass(ClassLoader.java:357)                                                                         
        ... 2 more

当我查看文件时,所有导入都是最新的:

package iut.nantes.projetMRS.service;

import java.util.Calendar;
import java.util.Date;
import java.util.List;

import org.bson.types.ObjectId;
import org.mongodb.morphia.Datastore;
import org.mongodb.morphia.Morphia;
import org.mongodb.morphia.query.Query;
import org.mongodb.morphia.query.UpdateOperations;

import com.mongodb.MongoClient;
import iut.nantes.projetMRS.entity.EntityPersonne;

public class ServicePersonne {
    /*Error here ==>*/ MongoClient client = new MongoClient("localhost", 27017); //connect to mongodb
[...]

最后一件非常奇怪的事情是,当我在自己的计算机上启动我的应用程序时,一切正常,我得到0错误并找到MongoClient。

我看过这里:https://stackoverflow.com/questions/45045681/how-do-i-fix-a-noclassdeffounderror-for-mongoclient-in-my-sparkjava-app但没有人回答他

我找到了一些答案,但没有一个能适用于我的案例。

下面我将向您展示我的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>iut.nantes</groupId>
    <artifactId>projetMRS</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>projetMRS</name>
    <url>http://maven.apache.org</url>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.3</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>3.0.0</version>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <mainClass>iut.nantes.projetMRS.Api</mainClass>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>3.8.1</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>mongo-java-driver</artifactId>
            <version>3.6.3</version>
        </dependency>
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>mongodb-driver</artifactId>
            <version>3.6.3</version>
        </dependency>
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>mongodb-driver-core</artifactId>
            <version>3.6.3</version>
        </dependency>
        <dependency>
            <groupId>com.sparkjava</groupId>
            <artifactId>spark-core</artifactId>
            <version>2.3</version>
        </dependency>
        <dependency>
            <groupId>org.mongodb</groupId>
            <artifactId>bson</artifactId>
            <version>3.6.3</version>
        </dependency>
        <dependency>
            <groupId>org.mongodb.morphia</groupId>
            <artifactId>morphia</artifactId>
            <version>1.3.2</version>
        </dependency>
        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.3.1</version>
        </dependency>
    </dependencies>
</project>

1 个答案:

答案 0 :(得分:3)

您确定jar中包含必要的MongoDB类吗?您可以通过在vim中打开jar并搜索&#34; com / mongodb / MongoClient&#34;来确认。

如果没有包含,你可以尝试maven assembly plugin来创建一个胖罐并重新运行命令。

我不确定Spark会进入这张照片的位置。但如果你最终会使用spark-submit,你肯定需要一个胖罐。