Не удается подключиться к MongoDb с Morphia - PullRequest
0 голосов
/ 02 мая 2018

Я пытаюсь использовать Morphia для чтения из MongoDb. Я использую Mongo v3.6.4. Я добавил зависимость Morphia:

<dependencies>
    <dependency>
        <groupId>org.mongodb.morphia</groupId>
        <artifactId>morphia</artifactId>
        <version>1.3.1</version>
    </dependency>
</dependencies>

Теперь я пытаюсь подключиться к своему MongoDb:

final Morphia morphia = new Morphia();
morphia.mapPackage("org.mongodb.morphia.example");
final Datastore datastore = morphia.createDatastore(new MongoClient("localhost", 27017), "redmatter");

Но я получаю ошибку:

Exception in thread "pool-1-thread-1" java.lang.NoClassDefFoundError: org/bson/conversions/Bson
    at org.mongodb.morphia.Morphia.createDatastore(Morphia.java:90)
    at com.ie.pereda.server.GraphHandler.handle(GraphHandler.java:44)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:79)
    at sun.net.httpserver.AuthFilter.doFilter(AuthFilter.java:83)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:82)
    at sun.net.httpserver.ServerImpl$Exchange$LinkHandler.handle(ServerImpl.java:675)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:79)
    at sun.net.httpserver.ServerImpl$Exchange.run(ServerImpl.java:647)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)
Caused by: java.lang.ClassNotFoundException: org.bson.conversions.Bson
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:335)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357)

У меня нет проблем с подключением к той же базе данных Mondo, когда я делаю:

MongoClient mongoClient = new MongoClient(new MongoClientURI("mongodb://localhost:27017"));
DB database = mongoClient.getDB("redmatter");

Это не проблема. В чем может быть проблема с Морфией?

EDIT

@ Решение Виктора, похоже, устранило эту проблему, но представило новую:

Exception in thread "pool-1-thread-1" java.lang.NoSuchMethodError: com.mongodb.MongoClient.getDatabase(Ljava/lang/String;)Lcom/mongodb/client/MongoDatabase;
    at org.mongodb.morphia.DatastoreImpl.<init>(DatastoreImpl.java:114)
    at org.mongodb.morphia.DatastoreImpl.<init>(DatastoreImpl.java:99)
    at org.mongodb.morphia.Morphia.createDatastore(Morphia.java:90)
    at com.ie.pereda.server.GraphHandler.handle(GraphHandler.java:44)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:79)
    at sun.net.httpserver.AuthFilter.doFilter(AuthFilter.java:83)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:82)
    at sun.net.httpserver.ServerImpl$Exchange$LinkHandler.handle(ServerImpl.java:675)
    at com.sun.net.httpserver.Filter$Chain.doFilter(Filter.java:79)
    at sun.net.httpserver.ServerImpl$Exchange.run(ServerImpl.java:647)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)
    at java.lang.Thread.run(Thread.java:748)    

Mongo определенно работает как мой предыдущий код для подключения работ ...

1 Ответ

0 голосов
/ 02 мая 2018

Попробуйте добавить зависимость maven

<dependency>
    <groupId>org.mongodb</groupId>
    <artifactId>bson</artifactId>
    <version>3.6.3</version>
</dependency>
...