Liberty Airflow
Project description
📖 Liberty Airflow
A Scalable and Extensible FastAPI and React Scheduler prebuilt with Airflow
Airflow Setup Guide
📌 Prerequisites
Before installing Airflow, ensure you have the following installed on your system:
- Python 3.12
- PostgreSQL (for database storage)
- Git (if needed for repository usage)
🔧 Step 1: Create a .env File
Airflow requires environment variables to be set. Create a .env file in the project root and configure it as follows:
# Airflow and Python Version
AIRFLOW_VERSION=2.10.5
PYTHON_VERSION=3.12
# PostgreSQL Config
POSTGRES_HOST=localhost
POSTGRES_PORT=5432
POSTGRES_DB=test
POSTGRES_USER=test
POSTGRES_PASSWORD=your_password_here # Replace with a secure password
# Admin PostgreSQL Config
POSTGRES_ADMIN_DB=liberty
POSTGRES_ADMIN_USER=liberty
POSTGRES_ADMIN_PASSWORD=your_secure_admin_password_here # Replace with a secure password
# Airflow Config
AIRFLOW_HOME="./"
AIRFLOW__CORE__LOAD_EXAMPLES="False"
AIRFLOW__DATABASE__LOAD_DEFAULT_CONNECTIONS="False"
AIRFLOW__WEBSERVER__EXPOSE_CONFIG="True"
AIRFLOW__CORE__EXECUTOR="LocalExecutor"
AIRFLOW__WEBSERVER__WEB_SERVER_PORT=8081 # Replace with your port
AIRFLOW__WEBSERVER__BASE_URL="http://localhost:8081/airflow" # Replace with your URL
PYTHONWARNINGS="ignore::SyntaxWarning"
AIRFLOW__DATABASE__SQL_ALCHEMY_CONN=postgresql+psycopg2://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB}
AIRFLOW__WEBSERVER__SECRET_KEY=your_secret_key_here # Replace with a secure secret key
AIRFLOW__API__AUTH_BACKENDS=airflow.api.auth.backend.basic_auth
SCARF_ANALYTICS=false
# Default Airflow Admin User
AIRFLOW_ADMIN_USER=admin
AIRFLOW_ADMIN_EMAIL=admin@example.com
AIRFLOW_ADMIN_PASSWORD=your_admin_password_here # Replace with a secure password
AIRFLOW_ADMIN_FIRSTNAME=Admin
AIRFLOW_ADMIN_LASTNAME=User
# FastAPI Config
FASTAPI_HOST="localhost"
FASTAPI_PORT=8082
⚠ IMPORTANT: Do not commit the
.envfile to version control. Keep credentials secure.
▶ Step 2: Install Liberty Airflow
pip install liberty-airflow
This script will preconfigure the environment for Airflow installation
▶ Step 3: Install Airflow
To install Airflow and set up the database, run:
airflow-install
This script will:
- Install Airflow and required dependencies
- Create the PostgreSQL database and user (if not already created)
- Initialize the Airflow database
- Create a default Airflow admin user
▶ Step 4: Start Airflow
To start Airflow services, run:
liberty-start
This will:
- Start the Airflow Scheduler
- Start the Airflow Webserver
- Start FastAPI
Once started, you can access Airflow at: 👉 http://localhost:8081/airflow
⏹ Step 5: Stop Airflow
To stop all running Airflow processes, run:
airflow-stop
This will:
- Stop the Airflow Scheduler
- Stop the Airflow Webserver
🛠 Troubleshooting
- If Airflow does not start, check the logs in the
logs/directory. - Ensure PostgreSQL is running and accessible
✅ Next Steps
- Configure DAGs inside
$AIRFLOW_HOME/dags/. - Add Git integration using the configured
GIT_URL. - Secure your instance by updating passwords and secret keys.
✅ Prebuilt Dags
Daily DAGs
airflow-purge-daily-1: Purges old Airflow logs and metadata on a daily schedule (@daily).database-backup-daily-1: Backs up databases every day at 01:00 AM (00 1 * * *).
Weekly DAGs
database-purge-weekly-1: Performs database cleanup and purging on a weekly schedule (@weekly).
Unscheduled DAGs
airflow-sync-1: Synchronizes repositories as needed (manually triggered).
✅ Variables
The DAGs rely on Airflow Variables for configuration. These can be set in the Airflow UI (Admin -> Variables) or via the Airflow CLI.
| Variable Name | Description | Default Value |
|---|---|---|
airflow_retention_days |
Number of days to retain Airflow logs | 1 |
backup_directory |
Directory where backups are stored | /opt/git/backup |
backup_repository |
Name of the backup repository | liberty-backup |
backup_retention_days |
Number of days to retain database backups | 0 |
backup_to_git |
Whether to push backups to Git (True or False) |
True |
✅ Connections
The DAGs require predefined Airflow Connections to interact with external systems. These can be configured via Airflow UI (Admin -> Connections).
Git Connection (git_conn)
- Connection Type:
generic - Description: Used for performing Git operations (pull, push, etc.)
- Required Fields:
login,password,host
PostgreSQL Connection (liberty_conn)
- Connection Type:
postgres - Description: Database connection for Liberty Framework
- Required Fields:
login,password,host,port,schema - Defaults:
login:libertyhost:localhostport:5432
💖 Sponsorship
If you find Liberty Ariflow useful and would like to support its development, consider sponsoring us. Your contributions help maintain the project, add new features, and improve the documentation. Every contribution, big or small, is greatly appreciated!
To sponsor, visit: GitHub Sponsors or reach out to us directly.
📜 License
Liberty Airflow is open-source software licensed under the AGPL License.
📧 Contact & Support
If you have questions or need support:
- Email: franck.blettner@nomana-it.fr
- GitHub Issues: Report an issue
- Discussions: Join the conversation in the GitHub Discussions section.
⭐ If you find Liberty Airflow useful, consider giving it a star on GitHub!
git clone https://github.com/fblettner/liberty-airflow.git
cd liberty-framework
🚀 Let's build the future of business applications together! 🚀
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file liberty_airflow-1.0.6.tar.gz.
File metadata
- Download URL: liberty_airflow-1.0.6.tar.gz
- Upload date:
- Size: 11.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a90557af559ffbccfd9ff23b0d5187b2c5d57f4a7d77bcc3b46a6ec6dfc497d
|
|
| MD5 |
6205632d1ab2c78344336c19ce58c814
|
|
| BLAKE2b-256 |
a25adb745b52d9040c03375c93f4c46b53694a3f30fc7a6e901cff8c7fa830bd
|
File details
Details for the file liberty_airflow-1.0.6-py3-none-any.whl.
File metadata
- Download URL: liberty_airflow-1.0.6-py3-none-any.whl
- Upload date:
- Size: 11.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1739853fc31624066cd38b096e7f8d26331b2328198e388e866e61fcdb05c53f
|
|
| MD5 |
b672d4370fbb20735e8ecf3169b9039f
|
|
| BLAKE2b-256 |
21a4aed69f25a1569b8730f364902671160801cb9699088db973e31f71030444
|