forked from
tangled.org/knot-docker
Community maintained Docker config for the spindle server
1from golang:1.24-alpine as builder
2env KNOT_REPO_SCAN_PATH=/home/git/repositories
3env CGO_ENABLED=1
4
5arg TAG='v1.4.0-alpha'
6
7workdir /app
8run apk add git gcc musl-dev
9run git clone -b ${TAG} https://tangled.sh/@tangled.sh/core .
10run go build -o /usr/bin/knot -ldflags '-s -w -extldflags "-static"' ./cmd/knot
11
12from alpine:edge
13expose 5555
14expose 22
15
16label org.opencontainers.image.title='knot'
17label org.opencontainers.image.description='data server for tangled'
18label org.opencontainers.image.source='https://tangled.sh/@tangled.sh/knot-docker'
19label org.opencontainers.image.url='https://tangled.sh'
20label org.opencontainers.image.vendor='tangled.sh'
21label org.opencontainers.image.licenses='MIT'
22
23copy rootfs .
24run chmod -R 755 /etc/s6-overlay
25run apk add shadow s6-overlay execline openssl openssh git curl
26run useradd -s /bin/nologin -d /home/git git && openssl rand -hex 16 | passwd --stdin git
27run mkdir -p /home/git/repositories && chown -R git:git /home/git/repositories
28copy --from=builder /usr/bin/knot /usr/bin
29run mkdir /app && chown -R git:git /app
30
31healthcheck --interval=60s --timeout=30s --start-period=5s --retries=3 \
32 cmd curl -f http://localhost:5555 || exit 1
33
34entrypoint ["/init"]
35