All checks were successful
Build and Push Docker Images / Build Backend (FastAPI) (push) Successful in 32s
Build and Push Docker Images / Build Frontend (Next.js) (push) Successful in 1m5s
Build and Push Docker Images / Build Integrator (push) Successful in 57s
Build and Push Docker Images / Build Kestra Init (push) Successful in 32s
Build and Push Docker Images / Build Pipeline (Meltano + dbt + Airflow) (push) Successful in 32s
Build and Push Docker Images / Trigger Portainer Update (push) Successful in 0s
- Add AIRFLOW__CORE__DAGS_FOLDER env var in Dockerfile so it's always set - Run `airflow dags reserialize` after `db migrate` in init container so DAGs appear immediately without waiting for scheduler scan interval Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
40 lines
959 B
Docker
40 lines
959 B
Docker
FROM python:3.13-slim
|
|
|
|
WORKDIR /opt/pipeline
|
|
|
|
# System dependencies
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
gcc \
|
|
libpq-dev \
|
|
curl \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Python dependencies
|
|
COPY requirements.txt .
|
|
RUN pip install --no-cache-dir -r requirements.txt
|
|
|
|
# Install custom Singer taps
|
|
COPY plugins/ plugins/
|
|
RUN pip install --no-cache-dir \
|
|
./plugins/extractors/tap-uk-gias \
|
|
./plugins/extractors/tap-uk-ees \
|
|
./plugins/extractors/tap-uk-ofsted \
|
|
./plugins/extractors/tap-uk-parent-view \
|
|
./plugins/extractors/tap-uk-fbit \
|
|
./plugins/extractors/tap-uk-idaci
|
|
|
|
# Copy pipeline code
|
|
COPY meltano.yml .
|
|
COPY transform/ transform/
|
|
COPY scripts/ scripts/
|
|
COPY dags/ dags/
|
|
|
|
# dbt deps
|
|
RUN cd transform && dbt deps --profiles-dir . 2>/dev/null || true
|
|
|
|
ENV AIRFLOW_HOME=/opt/airflow
|
|
ENV AIRFLOW__CORE__DAGS_FOLDER=/opt/pipeline/dags
|
|
ENV PYTHONPATH=/opt/pipeline
|
|
|
|
CMD ["airflow", "api-server"]
|