-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstart_airflow.sh
executable file
·42 lines (37 loc) · 1.22 KB
/
start_airflow.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
#!/bin/bash
# https://docs.docker.com/config/containers/multi-service_container/
# Start scheduler
echo "Starting Scheduler"
airflow scheduler --daemon &
echo "Scheduler started"
status=$?
if [ $status -ne 0 ]; then
echo "Failed to start my_first_process: $status"
exit $status
fi
# Start the second process
echo "starting webserver"
airflow webserver -p 8080 -D &
echo "web server started"
status=$?
if [ $status -ne 0 ]; then
echo "Failed to start my_second_process: $status"
exit $status
fi
# Naive check runs checks once a minute to see if either of the processes exited.
# This illustrates part of the heavy lifting you need to do if you want to run
# more than one service in a container. The container exits with an error
# if it detects that either of the processes has exited.
# Otherwise it loops forever, waking up every 60 seconds
while sleep 60; do
ps aux |grep airflow |grep -q -v grep
PROCESS_1_STATUS=$?
ps aux |grep webserver |grep -q -v grep
PROCESS_2_STATUS=$?
# If the greps above find anything, they exit with 0 status
# If they are not both 0, then something is wrong
if [ $PROCESS_1_STATUS -ne 0 -o $PROCESS_2_STATUS -ne 0 ]; then
echo "One of the processes has already exited."
exit 1
fi
done