Compare commits

..

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

2 changed files with 21 additions and 33 deletions

View File

@ -33,33 +33,35 @@ steps:
- name: push-artifact - name: push-artifact
image: alpine:latest image: alpine:latest
environment: environment:
# Das Secret muss in Drone unter diesem Namen angelegt sein!
GITEA_TOKEN: GITEA_TOKEN:
from_secret: GITEA_TOKEN from_secret: GITEA_TOKEN
commands: commands:
- apk add --no-cache git - apk add --no-cache git
# Git Identität setzen # Git konfigurieren
- git config --global user.email "drone@ci.local" - git config --global user.email "drone@ci.local"
- git config --global user.name "Drone CI" - git config --global user.name "Drone CI"
# Repo direkt mit Token clonen (oauth2 ist der Standard-User für Gitea-Tokens) # Remote setzen
- git clone https://oauth2:$${GITEA_TOKEN}@git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2.git #- git remote set-url origin https://git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2
- cd EinfuehrungInDocker_Pipeline2
# Branch wechseln oder lokal erstellen # Repo clonen
- git clone https://git.efi.th-nuernberg.de/gitea/freudenreichan/EinfuehrungInDocker_Pipeline2.git
- cd EinfuehrungInDocker_Pipeline
# Branch wechseln oder erstellen
- git checkout drone-artifacts || git checkout -b drone-artifacts - git checkout drone-artifacts || git checkout -b drone-artifacts
# Die Datei aus dem vorherigen Kaniko-Step in das Repo-Verzeichnis kopieren # Artifact löschen und neu hinzufügen
- git rm --ignore-unmatch image.tar - git rm image.tar
- cp $DRONE_WORKSPACE/image.tar . - cp $DRONE_WORKSPACE/image.tar .
- git add image.tar - git add image.tar
# Commit erstellen (falls sich nichts geändert hat, geht es dank || echo weiter) # Commit nur wenn Änderungen vorhanden
- 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 versucht den Remote-Stand zu holen, falls der Branch auf Gitea schon existiert # Pull vor Push (um Konflikte zu vermeiden)
- git pull origin drone-artifacts || true - git pull || true
# Jetzt klappt der Push, weil die URL oben das Token enthält # Push
- git push --set-upstream origin drone-artifacts - git push

View File

@ -1,8 +1,9 @@
# Base-Image # Base-Image
FROM alpine:latest FROM ubuntu:latest
# Pakete installieren (alpine nutzt apk anstelle von apt-get!) # Pakete installieren
RUN apk update && apk add --no-cache build-base gcc curl vim net-tools RUN apt-get update
RUN apt-get install -y build-essential gcc curl vim net-tools
# Arbeitsverzeichnis setzen # Arbeitsverzeichnis setzen
WORKDIR /app WORKDIR /app
@ -16,21 +17,6 @@ RUN gcc -o deployment deployment.c
# Verzeichnis für Ausgabe anlegen # Verzeichnis für Ausgabe anlegen
RUN mkdir /output RUN mkdir /output
# Neuen nicht root-user anlegen und diesem die Rechte
# fuer die Arbeitsverzeichnisse geben
RUN addgroup -S newgroup && adduser -S newuser -G newgroup
RUN chown -R newuser:newgroup /app /output
# Benutzer wechseln
USER newuser
# Mount-Punkt fuer Laufzeit festlegen
VOLUME /output
# Healthcheck anlegen
# - prueft alle 10s ob die Datei output.txt erfolgreich erstellt wurde
# - wenn 'test -f' fehlschlaegt, wird der Container als 'unhealthy' markiert
HEALTHCHECK --interval=10s --timeout=3s CMD test -f /output/output.txt || exit 1
# Ausgabe wird ins Container-Dateisystem geschrieben # Ausgabe wird ins Container-Dateisystem geschrieben
ENTRYPOINT ["/bin/sh", "-c"] 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"]