Skip to content

Latest commit

 

History

History
94 lines (64 loc) · 3.24 KB

README.md

File metadata and controls

94 lines (64 loc) · 3.24 KB

data-pipelines

Data extraction and processing pipelines to power KlimaDAO products

Repository structure

  • agent: Files to build a docker image and make a Kubernetes deployment of a Prefect agent
  • flows: Python flow files
  • root directory: Deployment yaml files

How does it work

  • Deployments are installed on Prefect Cloud.
  • Prefect Cloud Schedules flow-runs following the instructions in the configured deployments
  • Agents pull flow-runs from their pool and executes them.
    • Agents download the flow code from github (Block github/flows)
    • Agents execute the python code. They use other blocks to store data (s3-bucket/dev for Development, s3-bucket/prod for production)

Setup a development environnement

This project requires python 3.7 or later

Create a python environnement and install dependencies

python3 -m venv venv
source venv/bin/activate
pip install --upgrade pip
pip install -r requirements.txt
prefect cloud login

And follow instructions to setup your API key

Run flows

In the flows directory

You can run flows manually. For instance

python raw_verra_data.py

When running flows manually, the behaviour can be altered by creating a .env file. See flows/.env.dist

You can bootstrap your develpoment environment by running the special flow build_all. It will run all the flows in the right order

python build_all.py

Manage deployments

Deployments are automatically uploaded to Prefect Cloud using github actions. To update deployments update the .github/workflows/deploy-prefect-cloud.yaml file

If you change the name of a deployment. The deployment with the previous name will still exist. You will need to delete it manually.

  • View deployments prefect deployments ls

  • Delete deployment prefect deployments delete <deployment_name>

Launch an agent

To launch an agent on the workpool dev-agent-pool for instance

prefect agent start -p dev-agent-pool

Manage datasets

Some flows are created to manage artifacts stored on S3 (or localy):

  • clean_up_latest_artifacts: Deletes all artefacts whose names finishes by -latest
  • clean_up_old_artifacts: Deletes all artefacts created more than one week ago (it is executed as a prefect scheduled task)
  • fetch_s3_artifacts: Copies all artefacts whose names finishes by -latest on S3 (or localy)

Those flows can be configured via environment variables or a .env file located in the flows directory

AWS_ACCESS_KEY_ID # ID for S3 storage
AWS_SECRET_ACCESS_KEY # Key for S3 storage
AWS_STORAGE # the S3 environnement to clean artifacts from or to read artefact froms in fetch_s3_artifacts case
DATA_PIPELINES_RESULT_STORAGE # Storage where to save the artifacts to in fetch_s3_artifacts case

Move to production

To move in production and avoid downtimes we can use the foloowing procedure.

  • Make sure that on staging the pipeline runs fine, the artifacts are good and the dash-app works.
  • replace the production artifacts with the staging artifacts using the fetch_s3_artifact flow and the following environment variables:
AWS_ACCESS_KEY_ID=xxx
AWS_SECRET_ACCESS_KEY=xxx
AWS_STORAGE=dev
DATA_PIPELINES_RESULT_STORAGE=s3-bucket/prod
  • Merge the staging branch of dash-app into the main branch
  • Merge the staging branch of data-pipelines into the main branch