Как вы используете секреты сборки Docker с Docker Compose? - PullRequest
0 голосов
/ 28 октября 2019

Используя командную строку docker build, я могу передать секрет сборки следующим образом

docker build \
  --secret=id=gradle.properties,src=$HOME/.gradle/gradle.properties \
  --build-arg project=template-ms \
  .

Затем использовать его в Dockerfile

# syntax = docker/dockerfile:1.0-experimental

FROM gradle:jdk12 AS build
COPY *.gradle .
RUN --mount=type=secret,target=/home/gradle/gradle.properties,id=gradle.properties gradle dependencies
COPY src/ src/
RUN --mount=type=secret,target=/home/gradle/gradle.properties,id=gradle.properties gradle build
RUN ls -lR build
FROM alpine AS unpacker
ARG project
COPY --from=build /home/gradle/build/libs/${project}.jar /tmp
RUN mkdir -p /opt/ms && unzip -q /tmp/${project}.jar -d /opt/ms && \
  mv /opt/ms/BOOT-INF/lib /opt/lib
FROM openjdk:12
EXPOSE 8080
WORKDIR /opt/ms
USER nobody
CMD ["java", "-Xdebug", "-Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=0.0.0.0:8000", "-Dnetworkaddress.cache.ttl=5", "org.springframework.boot.loader.JarLauncher"]
HEALTHCHECK --start-period=600s CMD curl --silent --output /dev/null http://localhost:8080/actuator/health
COPY --from=unpacker /opt/lib /opt/ms/BOOT-INF/lib
COPY --from=unpacker /opt/ms/ /opt/ms/

Я хочу сделать сборку, используяdocker-compose, но я не могу найти в docker-compose.yml ссылку , как передать secret.

Таким образом, разработчику просто нужно набрать docker-compose up

1 Ответ

0 голосов
/ 28 октября 2019

Вы можете использовать окружение или аргументы для передачи переменных в контейнер в docker-compose.

args: - secret=id=gradle.properties,src=$HOME/.gradle/gradle.properties

environment: - secret=id=gradle.properties,src=$HOME/.gradle/gradle.properties

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...