-
Notifications
You must be signed in to change notification settings - Fork 512
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update minimal dockerfiles to use multi-stage builds to achieve minim…
…alness. Signed-off-by: cyli <[email protected]>
- Loading branch information
Showing
2 changed files
with
53 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,19 +1,38 @@ | ||
FROM golang:1.9.4-alpine AS build-env | ||
RUN apk add --update git gcc libc-dev | ||
# Pin to the specific v3.0.0 version | ||
RUN go get -tags 'mysql postgres file' github.com/mattes/migrate/cli && mv /go/bin/cli /go/bin/migrate | ||
|
||
ENV NOTARYPKG github.com/theupdateframework/notary | ||
|
||
# Copy the local repo to the expected go path | ||
COPY . /go/src/${NOTARYPKG} | ||
WORKDIR /go/src/${NOTARYPKG} | ||
|
||
# Build notary-server | ||
RUN go install \ | ||
-tags pkcs11 \ | ||
-ldflags "-w -X ${NOTARYPKG}/version.GitCommit=`git rev-parse --short HEAD` -X ${NOTARYPKG}/version.NotaryVersion=`cat NOTARY_VERSION`" \ | ||
${NOTARYPKG}/cmd/notary-server | ||
|
||
|
||
FROM busybox:latest | ||
MAINTAINER David Lawrence "[email protected]" | ||
|
||
# the ln is for compatibility with the docker-compose.yml, making these | ||
# the line is for compatibility with the docker-compose.yml, making these | ||
# images a straight swap for the those built in the compose file. | ||
RUN mkdir -p /usr/bin /var/lib && ln -s /bin/env /usr/bin/env | ||
|
||
COPY ./bin/notary-server /usr/bin/notary-server | ||
COPY ./bin/migrate /usr/bin/migrate | ||
COPY ./bin/ld-musl-x86_64.so.1 /lib/ld-musl-x86_64.so.1 | ||
COPY ./fixtures /var/lib/notary/fixtures | ||
COPY ./migrations /var/lib/notary/migrations | ||
COPY --from=build-env /go/bin/notary-server /usr/bin/notary-server | ||
COPY --from=build-env /go/bin/migrate /usr/bin/migrate | ||
COPY --from=build-env /lib/ld-musl-x86_64.so.1 /lib/ld-musl-x86_64.so.1 | ||
COPY --from=build-env /go/src/github.com/theupdateframework/notary/migrations/ /var/lib/notary/migrations | ||
COPY --from=build-env /go/src/github.com/theupdateframework/notary/fixtures /var/lib/notary/fixtures | ||
RUN chmod 0600 /var/lib/notary/fixtures/database/* | ||
|
||
WORKDIR /var/lib/notary | ||
# SERVICE_NAME needed for migration script | ||
ENV SERVICE_NAME=notary_server | ||
EXPOSE 4443 | ||
|
||
ENTRYPOINT [ "/usr/bin/notary-server" ] | ||
CMD [ "-config=/var/lib/notary/fixtures/server-config-local.json" ] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,20 +1,40 @@ | ||
FROM golang:1.9.4-alpine AS build-env | ||
RUN apk add --update git gcc libc-dev | ||
# Pin to the specific v3.0.0 version | ||
RUN go get -tags 'mysql postgres file' github.com/mattes/migrate/cli && mv /go/bin/cli /go/bin/migrate | ||
|
||
ENV NOTARYPKG github.com/theupdateframework/notary | ||
|
||
# Copy the local repo to the expected go path | ||
COPY . /go/src/${NOTARYPKG} | ||
WORKDIR /go/src/${NOTARYPKG} | ||
|
||
# Build notary-signer | ||
RUN go install \ | ||
-tags pkcs11 \ | ||
-ldflags "-w -X ${NOTARYPKG}/version.GitCommit=`git rev-parse --short HEAD` -X ${NOTARYPKG}/version.NotaryVersion=`cat NOTARY_VERSION`" \ | ||
${NOTARYPKG}/cmd/notary-signer | ||
|
||
|
||
FROM busybox:latest | ||
MAINTAINER David Lawrence "[email protected]" | ||
|
||
# the ln is for compatibility with the docker-compose.yml, making these | ||
# the line is for compatibility with the docker-compose.yml, making these | ||
# images a straight swap for the those built in the compose file. | ||
RUN mkdir -p /usr/bin /var/lib && ln -s /bin/env /usr/bin/env | ||
|
||
COPY ./bin/notary-signer /usr/bin/notary-signer | ||
COPY ./bin/migrate /usr/bin/migrate | ||
COPY ./bin/ld-musl-x86_64.so.1 /lib/ld-musl-x86_64.so.1 | ||
COPY ./fixtures /var/lib/notary/fixtures | ||
COPY ./migrations /var/lib/notary/migrations | ||
COPY --from=build-env /go/bin/notary-signer /usr/bin/notary-signer | ||
COPY --from=build-env /go/bin/migrate /usr/bin/migrate | ||
COPY --from=build-env /lib/ld-musl-x86_64.so.1 /lib/ld-musl-x86_64.so.1 | ||
COPY --from=build-env /go/src/github.com/theupdateframework/notary/migrations/ /var/lib/notary/migrations | ||
COPY --from=build-env /go/src/github.com/theupdateframework/notary/fixtures /var/lib/notary/fixtures | ||
RUN chmod 0600 /var/lib/notary/fixtures/database/* | ||
|
||
WORKDIR /var/lib/notary | ||
# SERVICE_NAME needed for migration script | ||
ENV SERVICE_NAME=notary_signer | ||
ENV NOTARY_SIGNER_DEFAULT_ALIAS="timestamp_1" | ||
ENV NOTARY_SIGNER_TIMESTAMP_1="testpassword" | ||
|
||
ENTRYPOINT [ "/usr/bin/notary-signer" ] | ||
CMD [ "-config=/var/lib/notary/fixtures/signer-config-local.json" ] | ||
CMD [ "-config=/var/lib/notary/fixtures/signer-config-local.json" ] |