50 lines
1.3 KiB
YAML
50 lines
1.3 KiB
YAML
version: '3.8'
|
|
services:
|
|
postgres:
|
|
image: postgres:13
|
|
environment:
|
|
- POSTGRES_USER=airflow
|
|
- POSTGRES_PASSWORD=airflow
|
|
- POSTGRES_DB=airflow
|
|
volumes:
|
|
- postgres_data:/var/lib/postgresql/data
|
|
|
|
airflow-webserver:
|
|
build: .
|
|
user: "50000:0"
|
|
depends_on:
|
|
- postgres
|
|
environment:
|
|
- PYTHONPATH=/opt/airflow
|
|
- AIRFLOW__DATABASE__SQL_ALCHEMY_CONN=postgresql+psycopg2://airflow:airflow@postgres/airflow
|
|
- AIRFLOW__CORE__EXECUTOR=LocalExecutor
|
|
- AIRFLOW__CORE__LOAD_EXAMPLES=False
|
|
volumes:
|
|
- ./dags:/opt/airflow/dags
|
|
- ./scripts:/opt/airflow/scripts
|
|
- airflow_logs:/opt/airflow/logs
|
|
- airflow_plugins:/opt/airflow/plugins
|
|
ports:
|
|
- "8081:8080"
|
|
command: bash -c "airflow db upgrade && airflow webserver"
|
|
|
|
airflow-scheduler:
|
|
build: .
|
|
user: "50000:0"
|
|
depends_on:
|
|
- postgres
|
|
environment:
|
|
- PYTHONPATH=/opt/airflow
|
|
- AIRFLOW__DATABASE__SQL_ALCHEMY_CONN=postgresql+psycopg2://airflow:airflow@postgres/airflow
|
|
- AIRFLOW__CORE__EXECUTOR=LocalExecutor
|
|
volumes:
|
|
- ./dags:/opt/airflow/dags
|
|
- ./scripts:/opt/airflow/scripts
|
|
- airflow_logs:/opt/airflow/logs
|
|
- airflow_plugins:/opt/airflow/plugins
|
|
command: scheduler
|
|
|
|
volumes:
|
|
postgres_data:
|
|
airflow_logs:
|
|
airflow_plugins: |