fix: various docker issues
This commit is contained in:
		| @@ -1,7 +1,7 @@ | ||||
| # ==================== | ||||
| # --- Build Assets --- | ||||
| # ==================== | ||||
| FROM node:10-alpine AS assets | ||||
| FROM node:10.14-alpine AS assets | ||||
|  | ||||
| RUN apk update && \ | ||||
|     apk add yarn g++ make python --no-cache && \ | ||||
| @@ -25,7 +25,7 @@ RUN yarn --production | ||||
| # =============== | ||||
| # --- Release --- | ||||
| # =============== | ||||
| FROM node:10-alpine | ||||
| FROM node:10.14-alpine | ||||
| LABEL maintainer="requarks.io" | ||||
|  | ||||
| RUN apk update && \ | ||||
| @@ -42,6 +42,7 @@ COPY --from=assets /var/wiki/node_modules ./node_modules | ||||
| COPY ./server ./server | ||||
| COPY --from=assets /var/wiki/server/views ./server/views | ||||
| COPY ./dev/build/config.yml ./config.yml | ||||
| COPY ./dev/docker/wait.sh ./wait.sh | ||||
| COPY ./package.json ./package.json | ||||
| COPY ./LICENSE ./LICENSE | ||||
|  | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| # -- DEV DOCKERFILE -- | ||||
| # -- DO NOT USE IN PRODUCTION! -- | ||||
|  | ||||
| FROM node:10-alpine | ||||
| FROM node:10.14-alpine | ||||
| LABEL maintainer "requarks.io" | ||||
|  | ||||
| RUN apk update && \ | ||||
| @@ -11,6 +11,7 @@ RUN apk update && \ | ||||
| WORKDIR /var/wiki | ||||
| COPY package.json . | ||||
| RUN yarn --silent | ||||
| COPY ./dev/docker/init.sh ./init.sh | ||||
|  | ||||
| ENV dockerdev 1 | ||||
|  | ||||
|   | ||||
							
								
								
									
										51
									
								
								dev/docker/docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										51
									
								
								dev/docker/docker-compose.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,51 @@ | ||||
| # -- DEV DOCKER-COMPOSE -- | ||||
| # -- DO NOT USE IN PRODUCTION! -- | ||||
|  | ||||
| version: "3" | ||||
| services: | ||||
|  | ||||
|   redis: | ||||
|     image: redis:4-alpine | ||||
|     ports: | ||||
|       - "16379:6379" | ||||
|     logging: | ||||
|       driver: "none" | ||||
|     networks: | ||||
|       - wikinet | ||||
|  | ||||
|   db: | ||||
|     image: postgres:9-alpine | ||||
|     environment: | ||||
|       POSTGRES_DB: wiki | ||||
|       POSTGRES_PASSWORD: wikijsrocks | ||||
|       POSTGRES_USER: wikijs | ||||
|     logging: | ||||
|       driver: "none" | ||||
|     volumes: | ||||
|       - db-data:/var/lib/postgresql/data | ||||
|     networks: | ||||
|       - wikinet | ||||
|     ports: | ||||
|       - "15432:5432" | ||||
|  | ||||
|   wiki: | ||||
|     build: | ||||
|       context: . | ||||
|       dockerfile: dev/docker/Dockerfile | ||||
|     depends_on: | ||||
|       - db | ||||
|       - redis | ||||
|     networks: | ||||
|       - wikinet | ||||
|     ports: | ||||
|       - "3000:3000" | ||||
|     volumes: | ||||
|       - .:/var/wiki | ||||
|       - /var/wiki/node_modules | ||||
|     command: ["sh", "./dev/docker/init.sh"] | ||||
|  | ||||
| networks: | ||||
|   wikinet: | ||||
|  | ||||
| volumes: | ||||
|   db-data: | ||||
							
								
								
									
										7
									
								
								dev/docker/init.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								dev/docker/init.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | ||||
| #!/bin/sh | ||||
|  | ||||
| echo "Waiting for redis and postgres to start up..." | ||||
| bash ./dev/docker/wait.sh redis:6379 | ||||
| bash ./dev/docker/wait.sh db:5432 | ||||
| echo "=== READY ===" | ||||
| tail -f /dev/null | ||||
							
								
								
									
										178
									
								
								dev/docker/wait.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										178
									
								
								dev/docker/wait.sh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,178 @@ | ||||
| #!/usr/bin/env bash | ||||
| #   Use this script to test if a given TCP host/port are available | ||||
|  | ||||
| WAITFORIT_cmdname=${0##*/} | ||||
|  | ||||
| echoerr() { if [[ $WAITFORIT_QUIET -ne 1 ]]; then echo "$@" 1>&2; fi } | ||||
|  | ||||
| usage() | ||||
| { | ||||
|     cat << USAGE >&2 | ||||
| Usage: | ||||
|     $WAITFORIT_cmdname host:port [-s] [-t timeout] [-- command args] | ||||
|     -h HOST | --host=HOST       Host or IP under test | ||||
|     -p PORT | --port=PORT       TCP port under test | ||||
|                                 Alternatively, you specify the host and port as host:port | ||||
|     -s | --strict               Only execute subcommand if the test succeeds | ||||
|     -q | --quiet                Don't output any status messages | ||||
|     -t TIMEOUT | --timeout=TIMEOUT | ||||
|                                 Timeout in seconds, zero for no timeout | ||||
|     -- COMMAND ARGS             Execute command with args after the test finishes | ||||
| USAGE | ||||
|     exit 1 | ||||
| } | ||||
|  | ||||
| wait_for() | ||||
| { | ||||
|     if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then | ||||
|         echoerr "$WAITFORIT_cmdname: waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" | ||||
|     else | ||||
|         echoerr "$WAITFORIT_cmdname: waiting for $WAITFORIT_HOST:$WAITFORIT_PORT without a timeout" | ||||
|     fi | ||||
|     WAITFORIT_start_ts=$(date +%s) | ||||
|     while : | ||||
|     do | ||||
|         if [[ $WAITFORIT_ISBUSY -eq 1 ]]; then | ||||
|             nc -z $WAITFORIT_HOST $WAITFORIT_PORT | ||||
|             WAITFORIT_result=$? | ||||
|         else | ||||
|             (echo > /dev/tcp/$WAITFORIT_HOST/$WAITFORIT_PORT) >/dev/null 2>&1 | ||||
|             WAITFORIT_result=$? | ||||
|         fi | ||||
|         if [[ $WAITFORIT_result -eq 0 ]]; then | ||||
|             WAITFORIT_end_ts=$(date +%s) | ||||
|             echoerr "$WAITFORIT_cmdname: $WAITFORIT_HOST:$WAITFORIT_PORT is available after $((WAITFORIT_end_ts - WAITFORIT_start_ts)) seconds" | ||||
|             break | ||||
|         fi | ||||
|         sleep 1 | ||||
|     done | ||||
|     return $WAITFORIT_result | ||||
| } | ||||
|  | ||||
| wait_for_wrapper() | ||||
| { | ||||
|     # In order to support SIGINT during timeout: http://unix.stackexchange.com/a/57692 | ||||
|     if [[ $WAITFORIT_QUIET -eq 1 ]]; then | ||||
|         timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --quiet --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & | ||||
|     else | ||||
|         timeout $WAITFORIT_BUSYTIMEFLAG $WAITFORIT_TIMEOUT $0 --child --host=$WAITFORIT_HOST --port=$WAITFORIT_PORT --timeout=$WAITFORIT_TIMEOUT & | ||||
|     fi | ||||
|     WAITFORIT_PID=$! | ||||
|     trap "kill -INT -$WAITFORIT_PID" INT | ||||
|     wait $WAITFORIT_PID | ||||
|     WAITFORIT_RESULT=$? | ||||
|     if [[ $WAITFORIT_RESULT -ne 0 ]]; then | ||||
|         echoerr "$WAITFORIT_cmdname: timeout occurred after waiting $WAITFORIT_TIMEOUT seconds for $WAITFORIT_HOST:$WAITFORIT_PORT" | ||||
|     fi | ||||
|     return $WAITFORIT_RESULT | ||||
| } | ||||
|  | ||||
| # process arguments | ||||
| while [[ $# -gt 0 ]] | ||||
| do | ||||
|     case "$1" in | ||||
|         *:* ) | ||||
|         WAITFORIT_hostport=(${1//:/ }) | ||||
|         WAITFORIT_HOST=${WAITFORIT_hostport[0]} | ||||
|         WAITFORIT_PORT=${WAITFORIT_hostport[1]} | ||||
|         shift 1 | ||||
|         ;; | ||||
|         --child) | ||||
|         WAITFORIT_CHILD=1 | ||||
|         shift 1 | ||||
|         ;; | ||||
|         -q | --quiet) | ||||
|         WAITFORIT_QUIET=1 | ||||
|         shift 1 | ||||
|         ;; | ||||
|         -s | --strict) | ||||
|         WAITFORIT_STRICT=1 | ||||
|         shift 1 | ||||
|         ;; | ||||
|         -h) | ||||
|         WAITFORIT_HOST="$2" | ||||
|         if [[ $WAITFORIT_HOST == "" ]]; then break; fi | ||||
|         shift 2 | ||||
|         ;; | ||||
|         --host=*) | ||||
|         WAITFORIT_HOST="${1#*=}" | ||||
|         shift 1 | ||||
|         ;; | ||||
|         -p) | ||||
|         WAITFORIT_PORT="$2" | ||||
|         if [[ $WAITFORIT_PORT == "" ]]; then break; fi | ||||
|         shift 2 | ||||
|         ;; | ||||
|         --port=*) | ||||
|         WAITFORIT_PORT="${1#*=}" | ||||
|         shift 1 | ||||
|         ;; | ||||
|         -t) | ||||
|         WAITFORIT_TIMEOUT="$2" | ||||
|         if [[ $WAITFORIT_TIMEOUT == "" ]]; then break; fi | ||||
|         shift 2 | ||||
|         ;; | ||||
|         --timeout=*) | ||||
|         WAITFORIT_TIMEOUT="${1#*=}" | ||||
|         shift 1 | ||||
|         ;; | ||||
|         --) | ||||
|         shift | ||||
|         WAITFORIT_CLI=("$@") | ||||
|         break | ||||
|         ;; | ||||
|         --help) | ||||
|         usage | ||||
|         ;; | ||||
|         *) | ||||
|         echoerr "Unknown argument: $1" | ||||
|         usage | ||||
|         ;; | ||||
|     esac | ||||
| done | ||||
|  | ||||
| if [[ "$WAITFORIT_HOST" == "" || "$WAITFORIT_PORT" == "" ]]; then | ||||
|     echoerr "Error: you need to provide a host and port to test." | ||||
|     usage | ||||
| fi | ||||
|  | ||||
| WAITFORIT_TIMEOUT=${WAITFORIT_TIMEOUT:-15} | ||||
| WAITFORIT_STRICT=${WAITFORIT_STRICT:-0} | ||||
| WAITFORIT_CHILD=${WAITFORIT_CHILD:-0} | ||||
| WAITFORIT_QUIET=${WAITFORIT_QUIET:-0} | ||||
|  | ||||
| # check to see if timeout is from busybox? | ||||
| WAITFORIT_TIMEOUT_PATH=$(type -p timeout) | ||||
| WAITFORIT_TIMEOUT_PATH=$(realpath $WAITFORIT_TIMEOUT_PATH 2>/dev/null || readlink -f $WAITFORIT_TIMEOUT_PATH) | ||||
| if [[ $WAITFORIT_TIMEOUT_PATH =~ "busybox" ]]; then | ||||
|         WAITFORIT_ISBUSY=1 | ||||
|         WAITFORIT_BUSYTIMEFLAG="-t" | ||||
|  | ||||
| else | ||||
|         WAITFORIT_ISBUSY=0 | ||||
|         WAITFORIT_BUSYTIMEFLAG="" | ||||
| fi | ||||
|  | ||||
| if [[ $WAITFORIT_CHILD -gt 0 ]]; then | ||||
|     wait_for | ||||
|     WAITFORIT_RESULT=$? | ||||
|     exit $WAITFORIT_RESULT | ||||
| else | ||||
|     if [[ $WAITFORIT_TIMEOUT -gt 0 ]]; then | ||||
|         wait_for_wrapper | ||||
|         WAITFORIT_RESULT=$? | ||||
|     else | ||||
|         wait_for | ||||
|         WAITFORIT_RESULT=$? | ||||
|     fi | ||||
| fi | ||||
|  | ||||
| if [[ $WAITFORIT_CLI != "" ]]; then | ||||
|     if [[ $WAITFORIT_RESULT -ne 0 && $WAITFORIT_STRICT -eq 1 ]]; then | ||||
|         echoerr "$WAITFORIT_cmdname: strict mode, refusing to execute subprocess" | ||||
|         exit $WAITFORIT_RESULT | ||||
|     fi | ||||
|     exec "${WAITFORIT_CLI[@]}" | ||||
| else | ||||
|     exit $WAITFORIT_RESULT | ||||
| fi | ||||
		Reference in New Issue
	
	Block a user