com.mongodb.MongoSocketOpenException: Exception opening socket
2312 ワード
SpringBootプロジェクトでは、Mongo接続コードが追加され、起動後にConsoleで次のような問題が発生しました.
ネット上ではSpringBootがmongodbをサポートするように自動的に構成されていると言われています.SpringBootを起動すると自動的にmongoインスタンスがインスタンス化され、自動構成を無効にする必要があります.
@SpringBootApplication(exclude=MongoAutoConfiguration.class)を追加して、自動構成を無効にします.
SpringBootエンジニアリング起動マスタークラスに追加された構成です
com.mongodb.MongoSocketOpenException: Exception opening socket
at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:70) ~[mongo-java-driver-3.10.2.jar:na]
at com.mongodb.internal.connection.InternalStreamConnection.open(InternalStreamConnection.java:126) ~[mongo-java-driver-3.10.2.jar:na]
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:117) ~[mongo-java-driver-3.10.2.jar:na]
at java.lang.Thread.run(Thread.java:748) [na:1.8.0_191]
Caused by: java.net.ConnectException: Connection refused: connect
at java.net.DualStackPlainSocketImpl.waitForConnect(Native Method) ~[na:1.8.0_191]
at java.net.DualStackPlainSocketImpl.socketConnect(DualStackPlainSocketImpl.java:85) ~[na:1.8.0_191]
at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) ~[na:1.8.0_191]
at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) ~[na:1.8.0_191]
at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) ~[na:1.8.0_191]
at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:172) ~[na:1.8.0_191]
at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) ~[na:1.8.0_191]
at java.net.Socket.connect(Socket.java:589) ~[na:1.8.0_191]
at com.mongodb.internal.connection.SocketStreamHelper.initialize(SocketStreamHelper.java:64) ~[mongo-java-driver-3.10.2.jar:na]
at com.mongodb.internal.connection.SocketStream.initializeSocket(SocketStream.java:79) ~[mongo-java-driver-3.10.2.jar:na]
at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:65) ~[mongo-java-driver-3.10.2.jar:na]
... 3 common frames omitted
ネット上ではSpringBootがmongodbをサポートするように自動的に構成されていると言われています.SpringBootを起動すると自動的にmongoインスタンスがインスタンス化され、自動構成を無効にする必要があります.
@SpringBootApplication(exclude=MongoAutoConfiguration.class)を追加して、自動構成を無効にします.
SpringBootエンジニアリング起動マスタークラスに追加された構成です
@SpringBootApplication(exclude = MongoAutoConfiguration.class)
@EnableEurekaClient
public class Startupmain {
public static void main(String[] args) {
SpringApplication.run( Startupmain.class, args );
}
}