【问题标题】:Cannot connect to MongoDb with Morphia无法使用 Morphia 连接到 MongoDb
【发布时间】:2018-05-01 21:00:15
【问题描述】:

我正在尝试使用 Morphia 从 MongoDb.Im 中读取,使用 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");

那连接没问题。 Morphia 的问题可能是什么?

编辑

@Victor 的解决方案似乎已经解决了这个问题,但提出了一个新问题:

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 肯定是作为我之前用于连接工作的代码运行的......

【问题讨论】:

  • 我相信是duplicate
  • 好的,这看起来像是错误的版本。请列出所有依赖项。
  • 请发布您的完整 pom.xml。您是否在驱动程序上声明了一个明确的 dep ?看起来是版本不匹配。

标签: java mongodb morphia


【解决方案1】:

尝试添加maven依赖

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

【讨论】:

  • 谢谢,这个问题已经通过了,但是现在有一个新问题,会更新问题
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2021-04-01
  • 2015-01-28
  • 2021-04-15
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2012-02-01
相关资源
最近更新 更多