92 lines
3.0 KiB
YAML
92 lines
3.0 KiB
YAML
|
# Mein Default Pipeline File:
|
|||
|
#
|
|||
|
# Macht einen einfachen Docker Build
|
|||
|
# und pusht das Ergebnis in die Container Registry
|
|||
|
# wobei bei nicht getaggten Builds das vorherige Image wieder aus der Registry gelöscht wird.
|
|||
|
#
|
|||
|
|
|||
|
# Wir verwenden mein Spezial-Docker-Image mit dem „reg“ Tool zum Löschen aus Registries.
|
|||
|
image: hub.fami.ga/root/docker:17
|
|||
|
|
|||
|
# Einfache 2-Stage Pipeline
|
|||
|
stages:
|
|||
|
- build
|
|||
|
- push
|
|||
|
|
|||
|
variables:
|
|||
|
DOCKER_DRIVER: overlay2
|
|||
|
CACHE_IMAGE: /cache
|
|||
|
|
|||
|
# Login in der Registry, sonst klappt’s nicht
|
|||
|
before_script:
|
|||
|
- docker login -u "$CI_REGISTRY_USER" -p "$CI_REGISTRY_PASSWORD" $CI_REGISTRY
|
|||
|
|
|||
|
# Der Docker Build …
|
|||
|
Build:
|
|||
|
stage: build
|
|||
|
script:
|
|||
|
# fetches the latest image (not failing if image is not found)
|
|||
|
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG || true
|
|||
|
- docker pull $CI_REGISTRY_IMAGE:latest || true
|
|||
|
#
|
|||
|
- echo "##### my Environment" && env && which curl && which reg && ls -la /usr/local/bin/ && echo "#####"
|
|||
|
- >
|
|||
|
docker build
|
|||
|
--pull
|
|||
|
--build-arg VCS_REF=$CI_COMMIT_SHA
|
|||
|
--build-arg VCS_URL=$CI_PROJECT_URL
|
|||
|
--cache-from $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
|||
|
--cache-from $CI_REGISTRY_IMAGE:latest
|
|||
|
--tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
|
|||
|
.
|
|||
|
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
|
|||
|
- echo "##### Build done..."
|
|||
|
|
|||
|
Clean previous:
|
|||
|
stage: build
|
|||
|
script:
|
|||
|
- echo "before ... ${CI_COMMIT_BEFORE_SHA} ... trying to remove?"
|
|||
|
- docker pull hub.fami.ga/root/docker:empty
|
|||
|
- docker tag hub.fami.ga/root/docker:empty $CI_REGISTRY_IMAGE:$CI_COMMIT_BEFORE_SHA
|
|||
|
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_BEFORE_SHA
|
|||
|
- /usr/local/bin/reg rm -d --auth-url $CI_REGISTRY -u $CI_REGISTRY_USER -p $CI_REGISTRY_PASSWORD $CI_REGISTRY_IMAGE:$CI_COMMIT_BEFORE_SHA
|
|||
|
- echo "##### Cleanup done..."
|
|||
|
|
|||
|
|
|||
|
Push slug:
|
|||
|
variables:
|
|||
|
GIT_STRATEGY: none
|
|||
|
stage: push
|
|||
|
except: [tags]
|
|||
|
script:
|
|||
|
- echo "##### Push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA -> $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG"
|
|||
|
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
|
|||
|
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
|||
|
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_REF_SLUG
|
|||
|
|
|||
|
|
|||
|
Push latest:
|
|||
|
variables:
|
|||
|
GIT_STRATEGY: none
|
|||
|
stage: push
|
|||
|
only: [tags]
|
|||
|
script:
|
|||
|
- echo "##### Push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA -> $CI_REGISTRY_IMAGE:latest"
|
|||
|
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
|
|||
|
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_REGISTRY_IMAGE:latest
|
|||
|
- docker push $CI_REGISTRY_IMAGE:latest
|
|||
|
|
|||
|
|
|||
|
Push tag:
|
|||
|
variables:
|
|||
|
GIT_STRATEGY: none
|
|||
|
stage: push
|
|||
|
only: [tags]
|
|||
|
script:
|
|||
|
- echo "##### Push $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA -> $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG"
|
|||
|
- docker pull $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA
|
|||
|
- docker tag $CI_REGISTRY_IMAGE:$CI_COMMIT_SHA $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG
|
|||
|
- docker push $CI_REGISTRY_IMAGE:$CI_COMMIT_TAG
|
|||
|
|
|||
|
|