forked from freudenreichan/EinfuehrungInDocker_Pipeline2
This commit is contained in:
parent
290a2c1eab
commit
2583ba4906
43
Dockerfile
43
Dockerfile
@ -1,47 +1,40 @@
|
||||
# syntax=docker/dockerfile:1
|
||||
|
||||
############################
|
||||
# 1) Builder: compilen
|
||||
############################
|
||||
FROM alpine:3.20 AS builder
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
# Build-Tools installieren
|
||||
# Build-Tools nur im Builder
|
||||
RUN apk add --no-cache build-base
|
||||
|
||||
# C-Datei kopieren und statisch kompilieren
|
||||
# Nur die C-Datei kopieren
|
||||
COPY deployment.c .
|
||||
|
||||
# Kompilieren (statisch linken)
|
||||
RUN gcc -O2 -static -s -o deployment deployment.c
|
||||
|
||||
# Wir nehmen das kleinste mögliche Image (ca. 2MB)
|
||||
############################
|
||||
# 2) Runtime: Minimaler Footprint
|
||||
############################
|
||||
FROM alpine:3.20
|
||||
|
||||
# 1. Metadaten (optional aber gut für CI/CD)
|
||||
LABEL maintainer="Security-Task"
|
||||
|
||||
# 2. Non-Root User erstellen
|
||||
# Wir erstellen eine Gruppe und einen User ohne Passwort
|
||||
RUN addgroup -S appgroup && adduser -S appuser -G appgroup
|
||||
|
||||
# 3. Arbeitsverzeichnis vorbereiten
|
||||
WORKDIR /app
|
||||
|
||||
# 4. Binary vom Builder kopieren
|
||||
# Binary vom Builder kopieren
|
||||
COPY --from=builder /app/deployment .
|
||||
|
||||
# 5. Output-Verzeichnis für das Volume erstellen
|
||||
# Wir müssen dem appuser die Rechte geben, damit er dort schreiben darf
|
||||
RUN mkdir /output && chown appuser:appgroup /output
|
||||
# Verzeichnis für das Volume erstellen
|
||||
RUN mkdir /output
|
||||
|
||||
# 6. Auf den Non-Root User wechseln
|
||||
USER appuser
|
||||
|
||||
# 7. HEALTHCHECK implementieren
|
||||
HEALTHCHECK --interval=30s --timeout=5s --start-period=5s --retries=3 \
|
||||
CMD ls -s /output/output.txt | grep -qE '^[1-9][0-9]*' || exit 1
|
||||
|
||||
# 8. Volume definieren
|
||||
# Damit die Daten permanent gespeichert werden können
|
||||
# Datavolume mounten (leitet die Ausgabe nach außen)
|
||||
VOLUME ["/output"]
|
||||
|
||||
# 9. Startbefehl
|
||||
# Healthcheck: Prüft, ob die Datei existiert und nicht leer ist
|
||||
HEALTHCHECK --interval=30s --timeout=5s --start-period=5s --retries=3 \
|
||||
CMD test -s /output/output.txt || exit 1
|
||||
|
||||
ENTRYPOINT ["/bin/sh", "-c"]
|
||||
CMD ["./deployment 10 > /output/output.txt && tail -f /output/output.txt"]
|
||||
Loading…
x
Reference in New Issue
Block a user