forked from IcaliaLabs/sepomex
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdev-entrypoint.sh
executable file
·52 lines (40 loc) · 2 KB
/
dev-entrypoint.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#! /bin/bash
# The Docker App Container's development entrypoint.
# This is a script used by the project's Docker development environment to
# setup the app containers and databases upon runnning.
set -e
: ${APP_PATH:="/usr/src/app"}
: ${APP_TEMP_PATH:="$APP_PATH/tmp"}
: ${APP_SETUP_LOCK:="$APP_TEMP_PATH/setup.lock"}
: ${APP_SETUP_WAIT:="5"}
# 1: Define the functions lock and unlock our app containers setup processes:
function lock_setup { mkdir -p $APP_TEMP_PATH && touch $APP_SETUP_LOCK; }
function unlock_setup { rm -rf $APP_SETUP_LOCK; }
function wait_setup { echo "Waiting for app setup to finish..."; sleep $APP_SETUP_WAIT; }
# 2: 'Unlock' the setup process if the script exits prematurely:
trap unlock_setup HUP INT QUIT KILL TERM
# 3: Wait until the setup 'lock' file no longer exists:
while [ -f $APP_SETUP_LOCK ]; do wait_setup; done
# 4: 'Lock' the setup process, to prevent a race condition when the project's
# app containers will try to install gems and setup the database concurrently:
lock_setup
# 5: Check or install the app dependencies via Bundler:
bundle check || bundle
# 6: Check if the database exists, or setup the database if it doesn't, as it is
# the case when the project runs for the first time.
#
# We'll use a custom script `check-or-setup-db` (inside our app's `bin` folder),
# instead of running `rake db:version || rake db:setup`, as running that command
# (at least on rails 4.2.4) will leave a couple of small ruby zombie processes
# running in the container:
bin/setup
# 7: 'Unlock' the setup process:
unlock_setup
# 8: Specify a default command, in case it wasn't issued:
if [[ "$3" = "rackup" ]]; then set -- "$@" -P /tmp/sepomex.pid; fi
# 9: If the command to execute is 'rails server', then force it to write the
# pid file into a non-shared container directory. Suddenly killing and removing
# app containers without this would leave a pidfile in the project's tmp dir,
# preventing the app container from starting up on further attempts:
# 10: Execute the given or default command:
exec "$@"