2020-02-18 23:55:06 -05:00
|
|
|
|
#!/bin/bash
|
|
|
|
|
|
2020-05-21 02:11:19 -04:00
|
|
|
|
DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
|
|
|
. "$DIR/.common.sh"
|
2020-02-18 23:55:06 -05:00
|
|
|
|
|
|
|
|
|
if [ "$1" == "" ]; then
|
|
|
|
|
echo "Waits for a docker container to be healthy."
|
|
|
|
|
echo "Usage: $0 docker-container"
|
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
SERVICE=$1
|
|
|
|
|
LOOPCOUNT=0
|
|
|
|
|
HEALTHY=
|
|
|
|
|
LIMIT=${2:-90}
|
|
|
|
|
|
|
|
|
|
echo -e "${BLUE}❯ ${CYAN}Waiting for healthy: ${YELLOW}${SERVICE}${RESET}"
|
|
|
|
|
|
|
|
|
|
until [ "${HEALTHY}" = "healthy" ]; do
|
|
|
|
|
echo -n "."
|
|
|
|
|
sleep 1
|
|
|
|
|
HEALTHY="$(docker inspect -f '{{.State.Health.Status}}' $SERVICE)"
|
|
|
|
|
((LOOPCOUNT++))
|
|
|
|
|
|
|
|
|
|
if [ "$LOOPCOUNT" == "$LIMIT" ]; then
|
|
|
|
|
echo -e "${BLUE}❯ ${RED}Timed out waiting for healthy${RESET}"
|
2024-05-20 22:53:07 -04:00
|
|
|
|
docker logs --tail 50 "$SERVICE"
|
2020-02-18 23:55:06 -05:00
|
|
|
|
exit 1
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
echo ""
|
|
|
|
|
echo -e "${BLUE}❯ ${GREEN}Healthy!${RESET}"
|