forked from aws/aws-mwaa-local-runner
-
Notifications
You must be signed in to change notification settings - Fork 2
/
mwaa-local-env
executable file
·122 lines (112 loc) · 3.9 KB
/
mwaa-local-env
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#!/bin/bash
AIRFLOW_VERSION=2_4
DOCKER_COMPOSE_PROJECT_NAME=aws-mwaa-local-runner-$AIRFLOW_VERSION
display_help() {
# Display Help
echo "======================================"
echo " MWAA Local Runner CLI"
echo "======================================"
echo "Syntax: mwaa-local-runner [command]"
echo
echo "---commands---"
echo "help Print CLI help"
echo "build-image Build Image Locally"
echo "reset-db Reset local PostgresDB container."
echo "start Start Airflow local environment. (LocalExecutor, Using postgres DB)\nYou cav start with -p flag to point to a custom dag folder"
echo "stop Stop Airflow local environment. (LocalExecutor, Using postgres DB)"
echo "test-requirements Install requirements on an ephemeral instance of the container."
echo "package-requirements Download requirements WHL files into plugins folder."
echo "validate-prereqs Validate pre-reqs installed (docker, docker-compose, python3, pip3)"
echo
}
validate_prereqs() {
docker -v >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo -e "'docker' is not installed or not runnable without sudo. \xE2\x9D\x8C"
else
echo -e "Docker is Installed. \xE2\x9C\x94"
fi
docker-compose -v >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo -e "'docker-compose' is not installed. \xE2\x9D\x8C"
else
echo -e "Docker compose is Installed. \xE2\x9C\x94"
fi
python3 --version >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo -e "Python3 is not installed. \xE2\x9D\x8C"
else
echo -e "Python3 is Installed \xE2\x9C\x94"
fi
pip3 --version >/dev/null 2>&1
if [ $? -ne 0 ]; then
echo -e "Pip3 is not installed. \xE2\x9D\x8C"
else
echo -e "Pip3 is Installed. \xE2\x9C\x94"
fi
}
build_image() {
docker build --rm --compress -t amazon/mwaa-local:$AIRFLOW_VERSION ./docker
}
airflow_cmd=$1
while true ; do
case "$2" in
-p )
shift
dag_path=$2
shift
;;
-r )
shift
requiremnets_path=$2
shift
;;
*)
break
;;
esac
done;
case "$airflow_cmd" in
validate-prereqs)
validate_prereqs
;;
test-requirements)
BUILT_IMAGE=$(docker images -q amazon/mwaa-local:$AIRFLOW_VERSION)
if [[ -n "$BUILT_IMAGE" ]]; then
echo "Container amazon/mwaa-local:$AIRFLOW_VERSION exists. Skipping build"
else
echo "Container amazon/mwaa-local:$AIRFLOW_VERSION not built. Building locally."
build_image
fi
docker run --platform linux/amd64 -v ${dag_path:-$(pwd)/dags}:/usr/local/airflow/dags -v $(pwd)/plugins:/usr/local/airflow/plugins -v ${requiremnets_path:-$(pwd)/requirements}:/usr/local/airflow/requirements -it amazon/mwaa-local:$AIRFLOW_VERSION test-requirements
;;
package-requirements)
BUILT_IMAGE=$(docker images -q amazon/mwaa-local:$AIRFLOW_VERSION)
if [[ -n "$BUILT_IMAGE" ]]; then
echo "Container amazon/mwaa-local:$AIRFLOW_VERSION exists. Skipping build"
else
echo "Container amazon/mwaa-local:$AIRFLOW_VERSION not built. Building locally."
build_image
fi
docker run -v $(pwd)/dags:/usr/local/airflow/dags -v $(pwd)/plugins:/usr/local/airflow/plugins -v $(pwd)/requirements:/usr/local/airflow/requirements -it amazon/mwaa-local:$AIRFLOW_VERSION package-requirements
;;
build-image)
build_image
;;
reset-db)
docker-compose -p $DOCKER_COMPOSE_PROJECT_NAME -f ./docker/docker-compose-resetdb.yml up --abort-on-container-exit
;;
start)
requiremnets_path=$requiremnets_path dag_path=$dag_path docker-compose -p $DOCKER_COMPOSE_PROJECT_NAME -f ./docker/docker-compose-local.yml up -d
;;
stop)
docker-compose -p $DOCKER_COMPOSE_PROJECT_NAME -f ./docker/docker-compose-local.yml down
;;
help)
display_help
;;
*)
echo "No command specified, displaying help"
display_help
;;
esac