2024-08-26 14:20:46 -04:00
FROM golang:1.22-alpine AS build
2023-11-01 14:37:25 -04:00
ARG TARGETARCH
ARG RELEASE
2024-08-26 14:20:46 -04:00
ENV GOPATH = /go
ENV CGO_ENABLED = 0
2023-11-01 14:37:25 -04:00
# Install curl and minisign
RUN apk add -U --no-cache ca-certificates && \
apk add -U --no-cache curl && \
2023-12-08 03:22:22 -05:00
go install aead.dev/minisign/cmd/minisign@v0.2.1
2023-11-01 14:37:25 -04:00
2024-08-15 11:48:04 -04:00
# Download minio binary and signature files
2023-11-01 14:37:25 -04:00
RUN curl -s -q https://dl.min.io/server/minio/release/linux-${ TARGETARCH } /archive/minio.${ RELEASE } -o /go/bin/minio && \
curl -s -q https://dl.min.io/server/minio/release/linux-${ TARGETARCH } /archive/minio.${ RELEASE } .minisig -o /go/bin/minio.minisig && \
2024-08-15 15:33:45 -04:00
curl -s -q https://dl.min.io/server/minio/release/linux-${ TARGETARCH } /archive/minio.${ RELEASE } .sha256sum -o /go/bin/minio.sha256sum && \
2023-11-01 14:37:25 -04:00
chmod +x /go/bin/minio
2024-08-15 11:48:04 -04:00
# Download mc binary and signature files
2023-11-01 14:37:25 -04:00
RUN curl -s -q https://dl.min.io/client/mc/release/linux-${ TARGETARCH } /mc -o /go/bin/mc && \
curl -s -q https://dl.min.io/client/mc/release/linux-${ TARGETARCH } /mc.minisig -o /go/bin/mc.minisig && \
2024-08-15 15:33:45 -04:00
curl -s -q https://dl.min.io/client/mc/release/linux-${ TARGETARCH } /mc.sha256sum -o /go/bin/mc.sha256sum && \
2023-11-01 14:37:25 -04:00
chmod +x /go/bin/mc
2024-03-30 05:41:51 -04:00
RUN if [ " $TARGETARCH " = "amd64" ] ; then \
curl -L -s -q https://github.com/moparisthebest/static-curl/releases/latest/download/curl-${ TARGETARCH } -o /go/bin/curl; \
chmod +x /go/bin/curl; \
fi
2023-11-01 14:37:25 -04:00
# Verify binary signature using public key "RWTx5Zr1tiHQLwG9keckT0c45M3AGeHD6IvimQHpyRywVWGbP1aVSGavRUN"
RUN minisign -Vqm /go/bin/minio -x /go/bin/minio.minisig -P RWTx5Zr1tiHQLwG9keckT0c45M3AGeHD6IvimQHpyRywVWGbP1aVSGav && \
minisign -Vqm /go/bin/mc -x /go/bin/mc.minisig -P RWTx5Zr1tiHQLwG9keckT0c45M3AGeHD6IvimQHpyRywVWGbP1aVSGav
FROM registry.access.redhat.com/ubi8/ubi-micro:latest
ARG RELEASE
LABEL name = "MinIO" \
vendor = "MinIO Inc <dev@min.io>" \
maintainer = "MinIO Inc <dev@min.io>" \
version = " ${ RELEASE } " \
release = " ${ RELEASE } " \
summary = "MinIO is a High Performance Object Storage, API compatible with Amazon S3 cloud storage service." \
description = "MinIO object storage is fundamentally different. Designed for performance and the S3 API, it is 100% open-source. MinIO is ideal for large, private cloud environments with stringent security requirements and delivers mission-critical availability across a diverse range of workloads."
ENV MINIO_ACCESS_KEY_FILE = access_key \
MINIO_SECRET_KEY_FILE = secret_key \
MINIO_ROOT_USER_FILE = access_key \
MINIO_ROOT_PASSWORD_FILE = secret_key \
MINIO_KMS_SECRET_KEY_FILE = kms_master_key \
MINIO_UPDATE_MINISIGN_PUBKEY = "RWTx5Zr1tiHQLwG9keckT0c45M3AGeHD6IvimQHpyRywVWGbP1aVSGav" \
MINIO_CONFIG_ENV_FILE = config.env \
MC_CONFIG_DIR = /tmp/.mc
2024-09-01 07:25:07 -04:00
RUN chmod 1777 /usr/bin
2023-11-01 14:37:25 -04:00
COPY --from= build /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
2024-08-18 03:13:33 -04:00
COPY --from= build /go/bin/minio* /usr/bin/
COPY --from= build /go/bin/mc* /usr/bin/
2024-03-30 05:41:51 -04:00
COPY --from= build /go/bin/cur* /usr/bin/
2023-11-01 14:37:25 -04:00
COPY CREDITS /licenses/CREDITS
COPY LICENSE /licenses/LICENSE
COPY dockerscripts/docker-entrypoint.sh /usr/bin/docker-entrypoint.sh
EXPOSE 9000
VOLUME [ "/data" ]
ENTRYPOINT [ "/usr/bin/docker-entrypoint.sh" ]
CMD [ "minio" ]