diff options
author | Dmitriy Volkov <wldhx@wldhx.me> | 2017-02-11 16:56:53 +0300 |
---|---|---|
committer | Dmitriy Volkov <wldhx@wldhx.me> | 2017-02-21 22:30:04 +0300 |
commit | 0b2fc0557f00753a552600da6e5c13d5617afaee (patch) | |
tree | 60d968aeb7a373737389895bade971fb698f102e /doc/ci | |
parent | 8a1441fb025bf9f46d42017e069382a44ade28d0 (diff) | |
download | gitlab-ce-0b2fc0557f00753a552600da6e5c13d5617afaee.tar.gz |
docs(ci/docker_build): Add example of variable use
Diffstat (limited to 'doc/ci')
-rw-r--r-- | doc/ci/docker/using_docker_build.md | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/doc/ci/docker/using_docker_build.md b/doc/ci/docker/using_docker_build.md index 28141cced3b..174fa8393e4 100644 --- a/doc/ci/docker/using_docker_build.md +++ b/doc/ci/docker/using_docker_build.md @@ -298,6 +298,30 @@ push to the Registry connected to your project. Its password is provided in the `$CI_BUILD_TOKEN` variable. This allows you to automate building and deployment of your Docker images. +You can also make use of [other variables](../variables/README.md) to avoid hardcoding: + +```yaml +services: + - docker:dind + +variables: + IMAGE_TAG: $CI_REGISTRY_IMAGE:$CI_BUILD_REF_NAME + +before_script: + - docker login -u gitlab-ci-token -p $CI_BUILD_TOKEN $CI_REGISTRY + +build: + stage: build + script: + - docker build -t $IMAGE_TAG . + - docker push $IMAGE_TAG +``` + +Here, `$CI_REGISTRY_IMAGE` would be resolved to the address of the registry tied +to this project, and `$CI_BUILD_REF_NAME` would be resolved to the branch or +tag name for this particular job. We also declare our own variable, `$IMAGE_TAG`, +combining the two to save us some typing in the `script` section. + Here's a more elaborate example that splits up the tasks into 4 pipeline stages, including two tests that run in parallel. The build is stored in the container registry and used by subsequent stages, downloading the image |