将服务容器连接到数据库容器

时间:2020-04-29 18:15:09

标签: spring-boot docker docker-compose

我是Docker的新手,并开始在我的小项目中玩它。

我已经使用以下Docker文件对服务本身进行了docker化:

ROM adoptopenjdk:11-jdk-hotspot AS DEPENDENCIES_BUILD_IMAGE
ENV APP_HOME=/usr/app/
WORKDIR $APP_HOME
COPY build.gradle settings.gradle gradlew $APP_HOME
COPY gradle $APP_HOME/gradle
RUN ./gradlew build || return 0
COPY . .
RUN ./gradlew build

FROM adoptopenjdk/openjdk11:jdk-11.0.7_10-alpine AS FINAL
ENV JAR_TEMPLATE=myapp-0.0.1-SNAPSHOT.jar
ENV ARTIFACT_NAME=myapp.jar
ENV APP_HOME=/usr/app
WORKDIR $APP_HOME
COPY --from=DEPENDENCIES_BUILD_IMAGE $APP_HOME/build/libs/$JAR_TEMPLATE .
RUN mv $JAR_TEMPLATE $ARTIFACT_NAME
EXPOSE 8080
CMD ["java", "-jar", "budget-calculator.jar"]

旁注-我知道我一直在复制0.0.1-SNAPSHOT的问题-但目前不确定如何解决。

之后,我想使用此确认将服务连接到具有docker-compose的Postgres DB:

version: '3'

services:
  backend:
    build: .
    container_name: myapp
    ports:
    - "8080:8080"
    links:
      - "db"
    depends_on:
      - db
    networks:
      - backend

  db:
    restart: unless-stopped
    image: postgres:10
    container_name: myapp-db
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=secret
      - POSTGRES_DB=myapp
    ports:
      - 5436:5436
    networks:
      - backend

networks:
  backend:

之后,我更新了application.properties文件,以指示数据库链接位于另一个容器上,如下所示:

spring.flyway.url=jdbc:postgresql://db:5436/myapp
spring.flyway.user=postgres
spring.flyway.password=secret
spring.flyway.baseline-on-migrate=true

spring.datasource.url=jdbc:postgresql://db:5436/myapp
spring.datasource.username=postgres
spring.datasource.password=secret
spring.datasource.driverClassName=org.postgresql.Driver

现在我有2个问题:

  1. 虽然我假设build: .每次都会重建我的图片 如果发生某些变化,我正在运行docker-compose up 实践中,我发现情况并非如此。
  2. 当后端服务启动flyway(迁移数据库库)时,请尝试 连接到数据库,但无法解析连接。

我在网上看到- links的使用已被弃用,我应该使用networks,但两者似乎都不起作用-我缺少什么?

1 个答案:

答案 0 :(得分:0)

我的配置有2个问题,第一个-Postgres的内部端口配置为5436,而映像的默认端口为5432(我已经更新了)他们两个都5432

第二个,为了将数据库的IP传递给服务,我在服务映像中添加了以下环境变量:

environment: # Pass environment variables to the service
      SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/budget
      SPRING_DATASOURCE_USERNAME: postgres
      SPRING_DATASOURCE_PASSWORD: secret
      SPRING_FLYWAY_URL: jdbc:postgresql://db:5432/budget
      SPRING_FLYWAY_USER: postgres
      SPRING_FLYWAY_PASSWORD: secret

所以我当前的工作配置是这样:

version: '3.8'

services:
  backend:
    build: .
    container_name: app-service
    ports:
    - "8080:8080"
    depends_on:
      - db
    environment: # Pass environment variables to the service
      SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/myapp
      SPRING_DATASOURCE_USERNAME: postgres
      SPRING_DATASOURCE_PASSWORD: secret
      SPRING_FLYWAY_URL: jdbc:postgresql://db:5432/myapp
      SPRING_FLYWAY_USER: postgres
      SPRING_FLYWAY_PASSWORD: secret

  db:
    restart: unless-stopped
    image: postgres:10
    environment:
      - POSTGRES_DB=myapp
      - POSTGRES_PASSWORD=postgres
      - POSTGRES_USER=secret
    volumes:
      - myapp_data:/var/lib/postgresql/data
    ports:
      - 5432:5432

volumes:
  myapp_data: