allow local image building without pushing
This commit is contained in:
parent
ba5021a889
commit
fd573a3b8f
4 changed files with 50 additions and 24 deletions
|
@ -34,7 +34,7 @@ script:
|
||||||
|
|
||||||
deploy:
|
deploy:
|
||||||
provider: script
|
provider: script
|
||||||
script: "./build-docker-push"
|
script: "./build-docker push"
|
||||||
skip_cleanup: true
|
skip_cleanup: true
|
||||||
on:
|
on:
|
||||||
branch: master
|
branch: master
|
||||||
|
|
|
@ -34,10 +34,16 @@ You can also use a copy of `go` hosted inside a Docker container if you prefix y
|
||||||
|
|
||||||
Once binaries are compiled you can build and push a dex image to quay.io. Before doing this step binaries must be built above using one of the build tools.
|
Once binaries are compiled you can build and push a dex image to quay.io. Before doing this step binaries must be built above using one of the build tools.
|
||||||
|
|
||||||
|
```console
|
||||||
|
./build-docker build
|
||||||
|
```
|
||||||
|
|
||||||
|
If you want to push the build to quay.io, use `./build-docker push`:
|
||||||
|
|
||||||
```console
|
```console
|
||||||
export DOCKER_USER=<<your user>>
|
export DOCKER_USER=<<your user>>
|
||||||
export DOCKER_PASSWORD=<<your password>>
|
export DOCKER_PASSWORD=<<your password>>
|
||||||
./build-docker-push
|
./build-docker push
|
||||||
```
|
```
|
||||||
|
|
||||||
By default the script pushes to `quay.io/coreos/dex`; if you want to push to a different repository, override the `DOCKER_REGISTRY` and `DOCKER_REPO` environment variables.
|
By default the script pushes to `quay.io/coreos/dex`; if you want to push to a different repository, override the `DOCKER_REGISTRY` and `DOCKER_REPO` environment variables.
|
||||||
|
|
40
build-docker
Executable file
40
build-docker
Executable file
|
@ -0,0 +1,40 @@
|
||||||
|
#!/bin/bash -e
|
||||||
|
#
|
||||||
|
# Build the docker container and push it to quay
|
||||||
|
# ./build-docker push
|
||||||
|
#
|
||||||
|
# Build the docker container locally without pushing to registry
|
||||||
|
# ./build-docker build
|
||||||
|
|
||||||
|
DOCKER_REGISTRY=${DOCKER_REGISTRY:=quay.io}
|
||||||
|
DOCKER_REPO=${DOCKER_REPO:=coreos/dex}
|
||||||
|
repo=$DOCKER_REGISTRY/$DOCKER_REPO
|
||||||
|
|
||||||
|
version=$(./git-version)
|
||||||
|
|
||||||
|
stage() {
|
||||||
|
echo -e "\033[36m----> $1\033[0m"
|
||||||
|
}
|
||||||
|
|
||||||
|
build() {
|
||||||
|
stage "build $repo:$version"
|
||||||
|
docker build -q --rm=true -t $repo:$version .
|
||||||
|
docker tag $repo:$version $repo:latest
|
||||||
|
}
|
||||||
|
|
||||||
|
push() {
|
||||||
|
stage "push image $repo:$version"
|
||||||
|
if [ -v $DOCKER_USER ] || [ -v $DOCKER_PASSWORD ]; then
|
||||||
|
echo "env variables not set: DOCKER_USER, DOCKER_PASSWORD. skipping login, assuming creds in .dockercfg"
|
||||||
|
else
|
||||||
|
echo logging in as $DOCKER_USER
|
||||||
|
docker login --username="$DOCKER_USER" --password="$DOCKER_PASSWORD" --email="dex@example.com" $DOCKER_REGISTRY
|
||||||
|
fi
|
||||||
|
|
||||||
|
docker push $repo:$version
|
||||||
|
docker push $repo:latest
|
||||||
|
}
|
||||||
|
|
||||||
|
test -z "$1" && build && push
|
||||||
|
test "$1" = "push" && build && push
|
||||||
|
test "$1" = "build" && build
|
|
@ -1,20 +0,0 @@
|
||||||
#!/bin/bash -e
|
|
||||||
|
|
||||||
|
|
||||||
DOCKER_REGISTRY=${DOCKER_REGISTRY:=quay.io}
|
|
||||||
DOCKER_REPO=${DOCKER_REPO:=coreos/dex}
|
|
||||||
repo=$DOCKER_REGISTRY/$DOCKER_REPO
|
|
||||||
|
|
||||||
if [ -v $DOCKER_USER ] || [ -v $DOCKER_PASSWORD ]; then
|
|
||||||
echo "env variables not set: DOCKER_USER, DOCKER_PASSWORD. skipping login, assuming creds in .dockercfg"
|
|
||||||
else
|
|
||||||
echo logging in as $DOCKER_USER
|
|
||||||
docker login --username="$DOCKER_USER" --password="$DOCKER_PASSWORD" --email="dex@example.com" $DOCKER_REGISTRY
|
|
||||||
fi
|
|
||||||
|
|
||||||
version=$(./git-version)
|
|
||||||
|
|
||||||
docker build -q --rm=true -t $repo:$version .
|
|
||||||
docker tag -f $repo:$version $repo:latest
|
|
||||||
docker push $repo:$version
|
|
||||||
docker push $repo:latest
|
|
Reference in a new issue