-
Notifications
You must be signed in to change notification settings - Fork 41.4k
Closed
Labels
theme: containersTestcontainers, Docker Compose and Buildpack featuresTestcontainers, Docker Compose and Buildpack featurestype: enhancementA general enhancementA general enhancement
Milestone
Description
Container instances should be started as early as possible and stopped as late as possible. This will help with #35201 and also reduce the likelihood of issues such as the one reported by @odrotbohm :
023-05-01T14:44:31.221+02:00 INFO 64148 --- [localhost:51526] org.mongodb.driver.cluster : Exception in monitor thread while connecting to server localhost:51526
com.mongodb.MongoSocketReadException: Prematurely reached end of stream
at com.mongodb.internal.connection.SocketStream.read(SocketStream.java:115)
at com.mongodb.internal.connection.SocketStream.read(SocketStream.java:138)
at com.mongodb.internal.connection.InternalStreamConnection.receiveResponseBuffers(InternalStreamConnection.java:735)
at com.mongodb.internal.connection.InternalStreamConnection.receiveMessageWithAdditionalTimeout(InternalStreamConnection.java:596)
at com.mongodb.internal.connection.InternalStreamConnection.receiveCommandMessageResponse(InternalStreamConnection.java:440)
at com.mongodb.internal.connection.InternalStreamConnection.receive(InternalStreamConnection.java:397)
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.lookupServerDescription(DefaultServerMonitor.java:227)
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:159)
at java.base/java.lang.Thread.run(Thread.java:833)
2023-05-01T14:44:31.316+02:00 DEBUG 64148 --- [ionShutdownHook] o.s.data.mongodb.core.MongoTemplate : find using query: { "completionDate" : null} fields: Document{{}} for class: class org.springframework.modulith.events.mongodb.MongoDbEventPublication in collection: org_springframework_modulith_events
2023-05-01T14:44:31.316+02:00 INFO 64148 --- [ionShutdownHook] org.mongodb.driver.cluster : Cluster description not yet available. Waiting for 30000 ms before timing out
2023-05-01T14:44:31.729+02:00 INFO 64148 --- [localhost:51526] org.mongodb.driver.cluster : Exception in monitor thread while connecting to server localhost:51526
com.mongodb.MongoSocketOpenException: Exception opening socket
at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:73)
at com.mongodb.internal.connection.InternalStreamConnection.open(InternalStreamConnection.java:204)
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.lookupServerDescription(DefaultServerMonitor.java:199)
at com.mongodb.internal.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:159)
at java.base/java.lang.Thread.run(Thread.java:833)
Caused by: java.net.ConnectException: Connection refused
at java.base/sun.nio.ch.Net.pollConnect(Native Method)
at java.base/sun.nio.ch.Net.pollConnectNow(Net.java:672)
at java.base/sun.nio.ch.NioSocketImpl.timedFinishConnect(NioSocketImpl.java:542)
at java.base/sun.nio.ch.NioSocketImpl.connect(NioSocketImpl.java:597)
at java.base/java.net.SocksSocketImpl.connect(SocksSocketImpl.java:327)
at java.base/java.net.Socket.connect(Socket.java:633)
at com.mongodb.internal.connection.SocketStreamHelper.initialize(SocketStreamHelper.java:107)
at com.mongodb.internal.connection.SocketStream.initializeSocket(SocketStream.java:82)
at com.mongodb.internal.connection.SocketStream.open(SocketStream.java:68)
... 4 common frames omitted
2023-05-01T14:45:01.322+02:00 WARN 64148 --- [ionShutdownHook] o.s.b.f.support.DisposableBeanAdapter : Invocation of destroy method failed on bean with name 'eventPublicationRegistry': org.springframework.dao.DataAccessResourceFailureException: Timed out after 30000 ms while waiting to connect. Client view of cluster state is {type=UNKNOWN, servers=[{address=localhost:51526, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketOpenException: Exception opening socket}, caused by {java.net.ConnectException: Connection refused}}]
This appears to be a lifecycle issue cause because a DisposableBean
wants to use a container service in their destroy
method.
Metadata
Metadata
Assignees
Labels
theme: containersTestcontainers, Docker Compose and Buildpack featuresTestcontainers, Docker Compose and Buildpack featurestype: enhancementA general enhancementA general enhancement