Compare commits

..

No commits in common. "drone-artifacts" and "main" have entirely different histories.

3 changed files with 21 additions and 31 deletions

View File

@ -46,15 +46,14 @@ steps:
#- git remote set-url origin https://git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2 #- git remote set-url origin https://git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2
# Repo clonen # Repo clonen
- git clone https://git.efi.th-nuernberg.de/gitea/weigmi87303/EinfuehrungInDocker_Pipeline2.git - git clone https://git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2.git
- cd EinfuehrungInDocker_Pipeline2 - cd EinfuehrungInDocker_Pipeline
- git remote set-url origin https://oauth2:$GITEA_TOKEN@git.efi.th-nuernberg.de/gitea/weigmi87303/EinfuehrungInDocker_Pipeline2.git
# Branch wechseln oder erstellen # Branch wechseln oder erstellen
- git checkout drone-artifacts || git checkout -b drone-artifacts - git checkout drone-artifacts || git checkout -b drone-artifacts
# Artifact löschen und neu hinzufügen # Artifact löschen und neu hinzufügen
- git rm -f image.tar || true - git rm image.tar
- cp $DRONE_WORKSPACE/image.tar . - cp $DRONE_WORKSPACE/image.tar .
- git add image.tar - git add image.tar
@ -62,7 +61,7 @@ steps:
- git commit -m "Add built Docker image [skip ci]" || echo "Nothing to commit" - git commit -m "Add built Docker image [skip ci]" || echo "Nothing to commit"
# Pull vor Push (um Konflikte zu vermeiden) # Pull vor Push (um Konflikte zu vermeiden)
- git pull origin drone-artifacts || true - git pull || true
# Push # Push
- git push -u origin drone-artifacts - git push

View File

@ -1,31 +1,22 @@
# ── Stage 1: Build ─────────────────────────────────────────────────────────── # Base-Image
FROM gcc:14-bookworm AS builder FROM ubuntu:latest
WORKDIR /build # Pakete installieren
COPY deployment.c . RUN apt-get update
RUN apt-get install -y build-essential gcc curl vim net-tools
RUN gcc -O2 -static -o deployment deployment.c # Arbeitsverzeichnis setzen
# ── Stage 2: Runtime ─────────────────────────────────────────────────────────
FROM alpine:3.21
# Alle Pakete auf neuesten Stand bringen → patcht libcrypto3/libssl3 auf 3.3.7-r0
RUN apk update && apk upgrade --no-cache
# Nicht-root-User anlegen
RUN addgroup -S appgroup && adduser -S appuser -G appgroup
# Output-Verzeichnis mit korrekten Rechten anlegen
RUN mkdir /output && chown appuser:appgroup /output
COPY --from=builder /build/deployment /app/deployment
VOLUME ["/output"]
USER appuser
WORKDIR /app WORKDIR /app
HEALTHCHECK --interval=30s --timeout=4s --start-period=10s --retries=3 \ # alles kopieren
CMD test -f /output/output.txt && test -s /output/output.txt || exit 1 COPY . .
ENTRYPOINT ["/bin/sh", "-c"] # Code kompilieren
RUN gcc -o deployment deployment.c
# Verzeichnis für Ausgabe anlegen
RUN mkdir /output
# Ausgabe wird ins Container-Dateisystem geschrieben
ENTRYPOINT ["/bin/bash", "-c"]
CMD ["./deployment 10 > /output/output.txt && tail -f /output/output.txt"] CMD ["./deployment 10 > /output/output.txt && tail -f /output/output.txt"]

BIN
image.tar

Binary file not shown.