mirror of
https://github.com/drakkan/sftpgo.git
synced 2024-11-25 00:50:31 +00:00
docker: add back Distroless image
this is possible thanks to a new project sponsor Signed-off-by: Nicola Murino <nicola.murino@gmail.com>
This commit is contained in:
parent
6074ed21f7
commit
0aa6013342
3 changed files with 83 additions and 0 deletions
15
.github/workflows/docker.yml
vendored
15
.github/workflows/docker.yml
vendored
|
@ -25,6 +25,9 @@ jobs:
|
||||||
- true
|
- true
|
||||||
- false
|
- false
|
||||||
include:
|
include:
|
||||||
|
- os: ubuntu-latest
|
||||||
|
docker_pkg: distroless
|
||||||
|
optional_deps: false
|
||||||
- os: ubuntu-latest
|
- os: ubuntu-latest
|
||||||
docker_pkg: debian-plugins
|
docker_pkg: debian-plugins
|
||||||
optional_deps: true
|
optional_deps: true
|
||||||
|
@ -61,6 +64,11 @@ jobs:
|
||||||
VERSION="${VERSION}-alpine"
|
VERSION="${VERSION}-alpine"
|
||||||
VERSION_SLIM="${VERSION}-slim"
|
VERSION_SLIM="${VERSION}-slim"
|
||||||
DOCKERFILE=Dockerfile.alpine
|
DOCKERFILE=Dockerfile.alpine
|
||||||
|
elif [[ $DOCKER_PKG == distroless ]]; then
|
||||||
|
VERSION="${VERSION}-distroless"
|
||||||
|
VERSION_SLIM="${VERSION}-slim"
|
||||||
|
DOCKERFILE=Dockerfile.distroless
|
||||||
|
FEATURES="${FEATURES},nosqlite"
|
||||||
elif [[ $DOCKER_PKG == debian-plugins ]]; then
|
elif [[ $DOCKER_PKG == debian-plugins ]]; then
|
||||||
VERSION="${VERSION}-plugins"
|
VERSION="${VERSION}-plugins"
|
||||||
VERSION_SLIM="${VERSION}-slim"
|
VERSION_SLIM="${VERSION}-slim"
|
||||||
|
@ -85,6 +93,13 @@ jobs:
|
||||||
fi
|
fi
|
||||||
TAGS="${TAGS},${DOCKER_IMAGE}:latest"
|
TAGS="${TAGS},${DOCKER_IMAGE}:latest"
|
||||||
TAGS_SLIM="${TAGS_SLIM},${DOCKER_IMAGE}:slim"
|
TAGS_SLIM="${TAGS_SLIM},${DOCKER_IMAGE}:slim"
|
||||||
|
elif [[ $DOCKER_PKG == distroless ]]; then
|
||||||
|
if [[ -n $MAJOR && -n $MINOR ]]; then
|
||||||
|
TAGS="${TAGS},${DOCKER_IMAGE}:${MINOR}-distroless,${DOCKER_IMAGE}:${MAJOR}-distroless"
|
||||||
|
TAGS_SLIM="${TAGS_SLIM},${DOCKER_IMAGE}:${MINOR}-distroless-slim,${DOCKER_IMAGE}:${MAJOR}-distroless-slim"
|
||||||
|
fi
|
||||||
|
TAGS="${TAGS},${DOCKER_IMAGE}:distroless"
|
||||||
|
TAGS_SLIM="${TAGS_SLIM},${DOCKER_IMAGE}:distroless-slim"
|
||||||
elif [[ $DOCKER_PKG == debian-plugins ]]; then
|
elif [[ $DOCKER_PKG == debian-plugins ]]; then
|
||||||
if [[ -n $MAJOR && -n $MINOR ]]; then
|
if [[ -n $MAJOR && -n $MINOR ]]; then
|
||||||
TAGS="${TAGS},${DOCKER_IMAGE}:${MINOR}-plugins,${DOCKER_IMAGE}:${MAJOR}-plugins"
|
TAGS="${TAGS},${DOCKER_IMAGE}:${MINOR}-plugins,${DOCKER_IMAGE}:${MAJOR}-plugins"
|
||||||
|
|
58
Dockerfile.distroless
Normal file
58
Dockerfile.distroless
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
FROM golang:1.21-bookworm as builder
|
||||||
|
|
||||||
|
ENV CGO_ENABLED=0 GOFLAGS="-mod=readonly"
|
||||||
|
|
||||||
|
RUN apt-get update && apt-get -y upgrade && apt-get install --no-install-recommends -y media-types openssh-server && rm -rf /var/lib/apt/lists/*
|
||||||
|
|
||||||
|
RUN mkdir -p /workspace
|
||||||
|
WORKDIR /workspace
|
||||||
|
|
||||||
|
ARG GOPROXY
|
||||||
|
|
||||||
|
COPY go.mod go.sum ./
|
||||||
|
RUN go mod download
|
||||||
|
|
||||||
|
ARG COMMIT_SHA
|
||||||
|
|
||||||
|
# This ARG allows to disable some optional features and it might be useful if you build the image yourself.
|
||||||
|
# For this variant we disable SQLite support since it requires CGO and so a C runtime which is not installed
|
||||||
|
# in distroless/static-* images
|
||||||
|
ARG FEATURES
|
||||||
|
|
||||||
|
COPY . .
|
||||||
|
|
||||||
|
RUN set -xe && \
|
||||||
|
export COMMIT_SHA=${COMMIT_SHA:-$(git describe --always --abbrev=8 --dirty)} && \
|
||||||
|
go build $(if [ -n "${FEATURES}" ]; then echo "-tags ${FEATURES}"; fi) -trimpath -ldflags "-s -w -X github.com/drakkan/sftpgo/v2/internal/version.commit=${COMMIT_SHA} -X github.com/drakkan/sftpgo/v2/internal/version.date=`date -u +%FT%TZ`" -v -o sftpgo
|
||||||
|
|
||||||
|
# Modify the default configuration file
|
||||||
|
RUN sed -i 's|"users_base_dir": "",|"users_base_dir": "/srv/sftpgo/data",|' sftpgo.json && \
|
||||||
|
sed -i 's|"backups"|"/srv/sftpgo/backups"|' sftpgo.json && \
|
||||||
|
sed -i 's|"sqlite"|"bolt"|' sftpgo.json
|
||||||
|
|
||||||
|
RUN mkdir /etc/sftpgo /var/lib/sftpgo /srv/sftpgo
|
||||||
|
|
||||||
|
FROM gcr.io/distroless/static-debian12
|
||||||
|
|
||||||
|
COPY --from=builder --chown=1000:1000 /etc/sftpgo /etc/sftpgo
|
||||||
|
COPY --from=builder --chown=1000:1000 /srv/sftpgo /srv/sftpgo
|
||||||
|
COPY --from=builder --chown=1000:1000 /var/lib/sftpgo /var/lib/sftpgo
|
||||||
|
COPY --from=builder --chown=1000:1000 /workspace/sftpgo.json /etc/sftpgo/sftpgo.json
|
||||||
|
COPY --from=builder --chown=1000:1000 /etc/ssh/moduli /etc/sftpgo/moduli
|
||||||
|
COPY --from=builder /workspace/templates /usr/share/sftpgo/templates
|
||||||
|
COPY --from=builder /workspace/static /usr/share/sftpgo/static
|
||||||
|
COPY --from=builder /workspace/openapi /usr/share/sftpgo/openapi
|
||||||
|
COPY --from=builder /workspace/sftpgo /usr/local/bin/
|
||||||
|
COPY --from=builder /etc/mime.types /etc/mime.types
|
||||||
|
|
||||||
|
# Log to the stdout so the logs will be available using docker logs
|
||||||
|
ENV SFTPGO_LOG_FILE_PATH=""
|
||||||
|
# These env vars are required to avoid the following error when calling user.Current():
|
||||||
|
# unable to get the current user: user: Current requires cgo or $USER set in environment
|
||||||
|
ENV USER=sftpgo
|
||||||
|
ENV HOME=/var/lib/sftpgo
|
||||||
|
|
||||||
|
WORKDIR /var/lib/sftpgo
|
||||||
|
USER 1000:1000
|
||||||
|
|
||||||
|
CMD ["sftpgo", "serve"]
|
|
@ -14,6 +14,7 @@ SFTPGo provides an official Docker image, it is available on both [Docker Hub](h
|
||||||
- [edge-alpine](../Dockerfile.alpine)
|
- [edge-alpine](../Dockerfile.alpine)
|
||||||
- [edge-slim](../Dockerfile)
|
- [edge-slim](../Dockerfile)
|
||||||
- [edge-alpine-slim](../Dockerfile.alpine)
|
- [edge-alpine-slim](../Dockerfile.alpine)
|
||||||
|
- [edge-distroless-slim](../Dockerfile.distroless)
|
||||||
|
|
||||||
## How to use the SFTPGo image
|
## How to use the SFTPGo image
|
||||||
|
|
||||||
|
@ -200,6 +201,15 @@ This image is based on the popular [Alpine Linux project](https://alpinelinux.or
|
||||||
|
|
||||||
This variant is highly recommended when final image size being as small as possible is desired. The main caveat to note is that it does use [musl libc](https://musl.libc.org/) instead of [glibc and friends](https://www.etalabs.net/compare_libcs.html), so certain software might run into issues depending on the depth of their libc requirements. However, most software doesn't have an issue with this, so this variant is usually a very safe choice. See [this Hacker News comment thread](https://news.ycombinator.com/item?id=10782897) for more discussion of the issues that might arise and some pro/con comparisons of using Alpine-based images.
|
This variant is highly recommended when final image size being as small as possible is desired. The main caveat to note is that it does use [musl libc](https://musl.libc.org/) instead of [glibc and friends](https://www.etalabs.net/compare_libcs.html), so certain software might run into issues depending on the depth of their libc requirements. However, most software doesn't have an issue with this, so this variant is usually a very safe choice. See [this Hacker News comment thread](https://news.ycombinator.com/item?id=10782897) for more discussion of the issues that might arise and some pro/con comparisons of using Alpine-based images.
|
||||||
|
|
||||||
|
### `sftpgo:<version>-distroless`
|
||||||
|
|
||||||
|
This image is based on the popular [Distroless project](https://github.com/GoogleContainerTools/distroless). We use the latest Debian based distroless image as base.
|
||||||
|
|
||||||
|
Distroless variant contains only a statically linked sftpgo binary and its minimal runtime dependencies and so it doesn't allow shell access (no shell is installed).
|
||||||
|
SQLite support is disabled since it requires CGO and so a C runtime which is not installed.
|
||||||
|
The default data provider is `bolt`, all the supported data providers except `sqlite` work.
|
||||||
|
We only provide the slim variant and so the optional `git` dependency is not available.
|
||||||
|
|
||||||
### `sftpgo:<suite>-slim`
|
### `sftpgo:<suite>-slim`
|
||||||
|
|
||||||
These tags provide a slimmer image that does not include `jq` and the optional `git` and `rsync` dependencies.
|
These tags provide a slimmer image that does not include `jq` and the optional `git` and `rsync` dependencies.
|
||||||
|
|
Loading…
Reference in a new issue