簡體   English   中英

Springboot Mongo docker-compose無法連接

[英]Springboot mongo docker-compose fail to connect

我的docker-compose.yml如圖所示

version: '3'
services:
  backend-service:
    image: 'storio-360-service:v1.0'
    build: .
    container_name: storio-360-service
    ports:
      - 8090:8080
    depends_on:
      - db_mongo
    links:
      - db_mongo
  db_mongo:
    image: 'mongo'
    container_name: db_mongo
    ports:
      - 27018:27017
    volumes:
      - /home/bob/Bob/data:/data/db
    restart: always

我的Dockerfile是

FROM openjdk:8u111-jdk-alpine
VOLUME /tmp
ADD /target/backend-service-1.0.1-SNAPSHOT.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
CMD curl "db_mongo:27018"

由於進行了此設置,因此我春季的存儲庫中包含以下代碼

@Repository
public class WatcherRepository {

    private MongoOperations mongoOps;

    @Autowired
    public WatcherRepository() {
        String myHost = "db_mongo";
        this.mongoOps = new MongoTemplate(new SimpleMongoDbFactory(new MongoClient(myHost), MongoConstant.DATABASE_NAME));
    }

    // Other code to access the mongo db
}

但是,當我運行docker-compose up --build時,

當Spring Boot啟動時,我得到以下信息:

02:24:55.871 [main] INFO  org.mongodb.driver.cluster - Cluster created with settings {hosts=[localhost:27017], mode=SINGLE, requiredClusterType=UNKNOWN, serverSelectionTimeout='30000 ms', maxWaitQueueSize=500}
storio-360-service    | 02:24:55.923 [cluster-ClusterId{value='5d3faa779470450001317225', description='null'}-localhost:27017] INFO  org.mongodb.driver.cluster - Exception in monitor thread while connecting to server localhost:27017
storio-360-service    | com.mongodb.MongoSocketOpenException: Exception opening socket
storio-360-service    |         at com.mongodb.connection.SocketStream.open(SocketStream.java:62)
storio-360-service    |         at com.mongodb.connection.InternalStreamConnection.open(InternalStreamConnection.java:126)
storio-360-service    |         at com.mongodb.connection.DefaultServerMonitor$ServerMonitorRunnable.run(DefaultServerMonitor.java:114)
storio-360-service    |         at java.lang.Thread.run(Thread.java:745)
storio-360-service    | Caused by: java.net.ConnectException: Connection refused (Connection refused)
storio-360-service    |         at java.net.PlainSocketImpl.socketConnect(Native Method)
storio-360-service    |         at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350)
storio-360-service    |         at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206)
storio-360-service    |         at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188)
storio-360-service    |         at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392)
storio-360-service    |         at java.net.Socket.connect(Socket.java:589)
storio-360-service    |         at com.mongodb.connection.SocketStreamHelper.initialize(SocketStreamHelper.java:59)
storio-360-service    |         at com.mongodb.connection.SocketStream.open(SocketStream.java:57)
storio-360-service    |         ... 3 common frames omitted
storio-360-service    | 02:24:56.060 [main] INFO  org.mongodb.driver.cluster - Cluster created with settings {hosts=[127.0.0.1:27017], mode=SINGLE, requiredClusterType=UNKNOWN, serverSelectionTimeout='30000 ms', maxWaitQueueSize=500

然后,Spring Boot將在成功設置后顯示正在等待呼叫。

02:34:39.274 [main] INFO  o.d.i.i.storio.service.Service - Started Service in 5.353 seconds (JVM running for 6.085)

但是,當我進行將調用mongodb的api調用時,它顯示了錯誤

Timed out after 30000 ms while waiting to connect. Client view of cluster state is {type=UNKNOWN, servers=[{address=127.0.0.1:27017, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketOpenException: Exception opening socket}, caused by {java.net.ConnectException: Connection refused (Connection refused)}}]; nested exception is com.mongodb.MongoTimeoutException: Timed out after 30000 ms while waiting to connect. Client view of cluster state is {type=UNKNOWN, servers=[{address=127.0.0.1:27017, type=UNKNOWN, state=CONNECTING, exception={com.mongodb.MongoSocketOpenException: Exception opening socket}, caused by {java.net.ConnectException: Connection refused (Connection refused)}}]

我是Docker的新手,很明顯,我的springboot無法訪問mongo。 我在Dockerfile或docker-compose中做錯了什么? 謝謝

看起來您正在將mongodb端口轉發到27018

   - 27018:27017

並且您還沒有在Spring配置中指定27018

因此,Spring Boot默認情況下會嘗試連接到27017

解決方案:要么刪除端口轉發,要么更新Spring Boot配置以使用mongo, 2701827018


更新:

這是一些Spring Boot OP的mongo自動配置技巧。

依賴於mongodb啟動器進行春季啟動

<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-data-mongodb -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-mongodb</artifactId>
    <version>2.1.6.RELEASE</version>
</dependency>

在應用程序屬性中提供Mongo DB詳細信息。

spring.data.mongodb.database= # Database name.
spring.data.mongodb.host= # Mongo server host. Cannot be set with URI.
spring.data.mongodb.password= # Login password of the mongo server. Cannot be set with URI.
spring.data.mongodb.port= # Mongo server port. Cannot be set with URI.
spring.data.mongodb.username= # Login user of the mongo server. Cannot be set with URI

(這里,OP需要指定他的mongodb主機和端口)

現在,剩下的唯一事情就是將MongoTemplate自動MongoTemplate到您想使用的位置。

@Autowired
private MongoTemplate mongoTemplate;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM