#!/bin/bash set -e DOCKER_TIMEOUT=20 # Wait 20 seconds for docker to start cleanup() { echo "[INFO] Running cleanup..." # Stop docker gracefully echo "[INFO] Stopping in container docker..." DOCKERPIDFILE=/var/run/docker.pid if [ -f $DOCKERPIDFILE ] && [ -s $DOCKERPIDFILE ] && pgrep -F $DOCKERPIDFILE; then kill "$(cat $DOCKERPIDFILE)" # Now wait for it to die STARTTIME=$(date +%s) ENDTIME=$(date +%s) while [ -f $DOCKERPIDFILE ] && [ -s $DOCKERPIDFILE ] && pgrep -F $DOCKERPIDFILE; do if [ $((ENDTIME - STARTTIME)) -le $DOCKER_TIMEOUT ]; then sleep 1 ENDTIME=$(date +%s) else echo "[ERROR] Timeout while waiting for in container docker to die" exit 1 fi done else echo "[WARN] Can't stop docker container" echo "[WARN] Your host might have been left with unreleased resources (ex. loop devices)" fi if [ "$1" == "fail" ]; then exit 1 fi } trap 'cleanup fail' SIGINT SIGTERM # Start docker echo "[INFO] Setup crosscompiling feature" mount binfmt_misc -t binfmt_misc /proc/sys/fs/binfmt_misc update-binfmts --enable qemu-arm update-binfmts --enable qemu-aarch64 # Start docker echo "[INFO] Starting docker." dockerd 2> /dev/null & echo "[INFO] Waiting for docker to initialize..." STARTTIME=$(date +%s) ENDTIME=$(date +%s) until docker info >/dev/null 2>&1; do if [ $((ENDTIME - STARTTIME)) -le $DOCKER_TIMEOUT ]; then sleep 1 ENDTIME=$(date +%s) else echo "[ERROR] Timeout while waiting for docker to come up" exit 1 fi done echo "[INFO] Docker was initialized" if [ "$DOCKER_CACHE" == "true" ]; then CACHE_CMD="--cache-from $DOCKER_IMAGE:latest" fi # Start barys with all the arguments requested echo "[INFO] Running build..." # Build docker build --pull --tag "$DOCKER_IMAGE:$DOCKER_TAG" "$CACHE_CMD" . docker tag "$DOCKER_IMAGE:$DOCKER_TAG" "$DOCKER_IMAGE:latest" echo "[INFO] Push image" if [ "$DOCKER_PUSH" == "true" ]; then # push docker push "$DOCKER_IMAGE:$DOCKER_TAG" docker push "$DOCKER_IMAGE:latest" fi cleanup "okay" exit 0