GitLab Runner: Docker-Image mit Docker-in-Docker bauen
Diese Dokumentation ist Teil des Docker-Images bauen-Leitfadens. Den vollständigen Leitfaden finden Sie hier: Bauen und pushen Sie Docker-Images direkt aus Ihren GitLab CI/CD-Pipelines mit Ihrem Stackhero Runner und Docker-in-Docker.
👋 Willkommen in der Stackhero-Dokumentation!
Stackhero bietet Ihnen eine benutzerfreundliche GitLab Runner Cloud-Lösung, die speziell dafür entwickelt wurde, Ihre GitLab CI/CD-Jobs effizient auszuführen. Das erwartet Sie:
- Unbegrenzte CI/CD-Minuten: Es gibt keine Abrechnung pro Minute, sodass Ihre Pipelines jederzeit ausgeführt werden können.
- Mehrere gleichzeitige Jobs: Führen Sie mehrere Jobs parallel aus, um Ihre gesamte Pipeline zu beschleunigen.
- Der Docker Executor mit Docker-in-Docker-Unterstützung: Optimieren Sie das Erstellen und Pushen Ihrer Container-Images.
- Kompatibel mit GitLab.com sowie jeder selbst gehosteten GitLab-Instanz.
- Eine private, dedizierte VM mit schnellen NVMe/SSD-Festplatten für konsistente und zuverlässige Builds.
- Verfügbar in den Regionen 🇪🇺 Europa und 🇺🇸 USA.
Sparen Sie Zeit: Sie können Ihren ersten GitLab Runner verbinden und Ihre Pipelines in nur wenigen Minuten starten!
Hier finden Sie ein Beispiel für eine .gitlab-ci.yml, die Sie zu Ihrem Repository hinzufügen können. Diese Konfiguration baut das Dockerfile, das sich im Root-Verzeichnis Ihres Projekts befindet:
build-image:
stage: build
image: docker:27
services:
- docker:27-dind
variables:
DOCKER_TLS_CERTDIR: "/certs"
before_script:
- docker info
script:
# Ersetzen Sie "my-image" durch den gewünschten Namen:
- docker build -t my-image .
# Optional können Sie einen kurzen Smoke-Test auf dem gebauten Image ausführen:
# - docker run --rm my-image /path/to/tests
In dieser Konfiguration startet der Service docker:27-dind den Docker-Daemon. Die Variable DOCKER_TLS_CERTDIR: "/certs" aktiviert eine sichere TLS-Verbindung zwischen Ihrem Job und dem Docker-Daemon.