Compare commits

..

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

3 changed files with 21 additions and 51 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,29 +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 adduser -D appuser
RUN mkdir /output && chown appuser /output
USER appuser
COPY --from=builder /build/deployment /app/deployment
VOLUME [ "/output" ]
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"]

View File

@ -1,22 +0,0 @@
# Base-Image
FROM ubuntu:latest
# Pakete installieren
RUN apt-get update
RUN apt-get install -y build-essential gcc curl vim net-tools
# Arbeitsverzeichnis setzen
WORKDIR /app
# alles kopieren
COPY . .
# 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"]