我遇到使用Spring引導和MongoDB外部驅動器的一些問題。我不能使用Spring Data MongoDB項目,因爲我需要使用Mongo提供的官方異步驅動程序。但是,我需要使用Spring Boot,因爲我正在開發的模塊是使用此庫的更大項目的一部分。春天引導入門的Web嘗試連接到蒙戈在啓動
這是我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/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<artifactId>tx-view</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- omissis -->
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.mongodb</groupId>
<artifactId>mongodb-driver-async</artifactId>
<version>${mongodb.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
詳細地說,我使用的是Spring Boot 1.4.1和Mongo Async Driver 3.2.2。
這是我的應用程序。
@SpringBootApplication(exclude = {MongoAutoConfiguration.class, MongoDataAutoConfiguration.class})
public class TxViewApplication {
public static void main(String[] args) {
SpringApplication.run(TxViewApplication.class, args);
}
@Value("${mongo.uri}")
private String mongoUri;
@Bean
public MongoClient mongoClient() {
return MongoClients.create(mongoUri);
}
}
它遵循的唯一(空)測試我的時刻。
@SpringBootTest
@RunWith(SpringRunner.class)
public class ApplicationTest {
@Test
public void loadContext() throws Exception {}
}
我在這個項目中沒有任何其他代碼。當我運行測試,我有以下錯誤:
2016-11-22 15:43:58.597 INFO 4572 --- [null'}-db:27017] org.mongodb.driver.cluster : Exception in monitor thread while connecting to server db:27017
com.mongodb.MongoException: java.io.IOException: Il computer remoto ha rifiutato la connessione di rete.
at com.mongodb.connection.InternalStreamConnection.open(InternalStreamConnection.java:125) ~[mongodb-driver-core-3.2.2.jar:na]
at com.mongodb.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:128) ~[mongodb-driver-core-3.2.2.jar:na]
at java.lang.Thread.run(Thread.java:745) [na:1.8.0_101]
Caused by: java.io.IOException: Il computer remoto ha rifiutato la connessione di rete.
at sun.nio.ch.Iocp.translateErrorToIOException(Iocp.java:309) ~[na:1.8.0_101]
at sun.nio.ch.Iocp.access$700(Iocp.java:46) ~[na:1.8.0_101]
at sun.nio.ch.Iocp$EventHandlerTask.run(Iocp.java:399) ~[na:1.8.0_101]
at sun.nio.ch.AsynchronousChannelGroupImpl$1.run(AsynchronousChannelGroupImpl.java:112) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) ~[na:1.8.0_101]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) ~[na:1.8.0_101]
... 1 common frames omitted
正如你所看到的,我已經正確爲了阻止春天啓動嘗試處理自己來蒙戈連接插入SpringBootApplication
註釋的exclude
條款如在Mongo tries to connect automatically to port 27017(localhost)中所建議的。
我也注意到,在spring-boot-starter-web
的依賴關係的pom.xml
被添加之後,我開始有錯誤。
我怎樣才能抑制春季啓動,試圖在啓動時自動連接到蒙戈?同步版本的MongoDB驅動程序也存在同樣的問題。
---編輯---
我還嘗試構建一個包裝圍繞async.MongoClient
對象,以這樣的方式
public class MongoWrapper {
private final MongoClient mongo;
public MongoWrapper() {
mongo = MongoClients.create();
}
public MongoClient getMongo() {
return mongo;
}
}
的配置也相應改變。
@Bean
public MongoWrapper mongo() {
return new MongoWrapper();
}
不幸的是,沒有任何改變。春季啓動似乎也攔截MongoClient
對象以這種方式:(
非常感謝。
也許'SpringBootTest'不使用'TxViewApplication'作爲上下文的源,因爲你在別的地方有另一個'@ SpringBootConfiguration'。如果你排除mongo,爲什麼你要在同一個類中定義一個'MongoClient'呢? –
我發佈的代碼是該項目中唯一的代碼。我將該配置合併到啓動應用程序的同一個類中,以使代碼更少。你的意思是我沒有在Spring配置中定義任何類型的MongoClient對象? –
@StephaneNicoll,您如何建議將MongoDB的異步java驅動程序與Spring Boot集成? –