Я делаю docker-compose и dockerfile для своего весеннего проекта, но он терпит неудачу на этапе сборки maven, потому что пытается установить соединение со службой postgres, я понятия не имею, как я могу это решить.
это мой файл для создания докеров:
version: '3'
services:
postgres:
build:
context: .
dockerfile: docker/postgres/Dockerfile
restart: always
environment:
POSTGRES_DB: ${postgres_database}
POSTGRES_USER: ${postgres_username}
POSTGRES_PASSWORD: ${postgres_password}
ports:
- '5432:5432'
volumes:
- ./pgdata:/var/lib/postgresql/data
api:
build:
context: .
dockerfile: docker/jdk/Dockerfile
restart: always
environment:
postgres_database: ${postgres_database}
postgres_username: ${postgres_username}
postgres_password: ${postgres_password}
ports:
- '8100:8080'
depends_on:
- postgres
мой докер файл postgres:
FROM postgres:11-alpine
ENV POSTGRES_DB: ${POSTGRES_DB}
ENV POSTGRES_USER: ${POSTGRES_USER}
ENV POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
COPY ./docker/postgres/init.sql /docker-entrypoint-initdb.d
EXPOSE 5432
мой jdk dockerfile, где я сделал сборку проекта (она не работает) и запустил банку:
FROM maven:3.6.0-jdk-11-slim AS build
COPY ./src /usr/src/app/src
COPY ./pom.xml /usr/src/app
RUN mvn -f /usr/src/app/pom.xml clean package
FROM adoptopenjdk/openjdk11:jre11u-alpine-nightly
COPY --from=build /src/usr/src/app/target/logger_service-0.0.1-SNAPSHOT.jar /usr/src/app/app.jar
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "/usr/app/app.jar"]
журнал ошибок:
[ERROR] Tests run: 1, Failures: 0, Errors: 1, Skipped: 0, Time elapsed: 14.844 s <<< FAILURE! - in cl.getcolors.loggerservice.LoggerServiceApplicationTests
[ERROR] contextLoads(cl.getcolors.loggerservice.LoggerServiceApplicationTests) Time elapsed: 0.014 s <<< ERROR!
java.lang.IllegalStateException: Failed to load ApplicationContext
Caused by: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'entityManagerFactory' defined in class path resource [org/springframework/boot/autoconfigure/orm/jpa/HibernateJpaConfiguration.class]: Invocation of init method failed; nested exception is javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to open JDBC Connection for DDL execution
Caused by: javax.persistence.PersistenceException: [PersistenceUnit: default] Unable to build Hibernate SessionFactory; nested exception is org.hibernate.exception.JDBCConnectionException: Unable to open JDBC Connection for DDL execution
Caused by: org.hibernate.exception.JDBCConnectionException: Unable to open JDBC Connection for DDL execution
Caused by: org.postgresql.util.PSQLException: The connection attempt failed.
Caused by: java.net.UnknownHostException: postgres
как я могу это исправить?




Я нашел решение, maven пытается выполнить тесты приложения, поэтому он выполняет вызов базы данных на основе конфигурации, это происходит с помощью команды mvn clean package. -DskipTests нужно добавить инструкцию к команде для запуска maven без тестов, чтобы можно было правильно собрать.
mvn clean package -DskipTests
мой dockerfile теперь выглядит так и отлично работает:
FROM maven:3.6.0-jdk-11-slim AS build
COPY ./src /usr/src/app/src
COPY ./pom.xml /usr/src/app
RUN mvn -f /usr/src/app/pom.xml clean package -DskipTests
FROM adoptopenjdk/openjdk11:jre11u-alpine-nightly
COPY --from=build /src/usr/src/app/target/logger_service-0.0.1-SNAPSHOT.jar /usr/src/app/app.jar
EXPOSE 8080
ENTRYPOINT ["java", "-jar", "/usr/app/app.jar"]
В дополнение к приведенному выше пояснению следует отметить, что при построении образа нет доступа к базе данных. Только после создания контейнеров программы получают доступ к базе данных.
Я думаю, что depend_on определяет только порядок запуска контейнеров. Вам нужна ссылка: docs.docker.com/compose/compose-file/#links