feat: optimize Docker build for production
All checks were successful
renovate / renovate (push) Successful in 19s
Docker Build and Push / build-and-push (push) Successful in 1m30s

This commit is contained in:
2025-12-28 19:29:32 +07:00
parent 1d918ef2aa
commit eee04daf80
3 changed files with 82 additions and 27 deletions

View File

@@ -1,20 +1,46 @@
FROM golang:1.25.5-alpine AS go_builder
RUN apk update && apk upgrade && \
apk add --no-cache ca-certificates tzdata git && \
update-ca-certificates
WORKDIR /src
COPY go.mod go.sum ./
RUN --mount=type=cache,target=/go/pkg/mod \
--mount=type=cache,target=/root/.cache/go-build \
go mod download && go mod verify
COPY . .
RUN apk update && apk upgrade && apk add --no-cache ca-certificates tzdata
RUN update-ca-certificates
RUN go build -o ./tmp/main
RUN --mount=type=cache,target=/go/pkg/mod \
--mount=type=cache,target=/root/.cache/go-build \
CGO_ENABLED=0 GOOS=linux GOARCH=amd64 \
go build -trimpath \
-ldflags="-w -s" \
-o /app/tunnel_pls \
.
RUN adduser -D -u 10001 -g '' appuser
FROM scratch
WORKDIR /src
COPY --from=go_builder /usr/share/zoneinfo /usr/share/zoneinfo
COPY --from=go_builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/
COPY --from=go_builder /src/tmp/main /src
COPY --from=go_builder /etc/passwd /etc/passwd
COPY --from=go_builder /etc/group /etc/group
COPY --from=go_builder /app/tunnel_pls /app/tunnel_pls
ENV TZ Asia/Jakarta
WORKDIR /app
ENTRYPOINT ["./main"]
USER appuser
ENV TZ=Asia/Jakarta
EXPOSE 2200 80 443
LABEL org.opencontainers.image.title="Tunnel Please" \
org.opencontainers.image.description="SSH-based tunnel server"
ENTRYPOINT ["/app/tunnel_pls"]