Installing from Sources¶
Released packages¶
This page describes downloading and verifying Apache Airflow® version
2.9.2
using officially released packages.
You can also install Apache Airflow
- as most Python packages - via PyPI.
You can choose different version of Airflow by selecting different version from the drop-down at
the top-left of the page.
The source
, sdist
and whl
packages released are the “official” sources of installation that you
can use if you want to verify the origin of the packages and want to verify checksums and signatures of
the packages. The packages are available via the
Official Apache Software Foundations Downloads
As of version 2.8 Airflow follows PEP 517/518 and uses pyproject.toml
file to define build dependencies
and build process and it requires relatively modern versions of packaging tools to get airflow built from
local sources or sdist
packages, as PEP 517 compliant build hooks are used to determine dynamic build
dependencies. In case of pip
it means that at least version 22.1.0 is needed (released at the beginning of
2022) to build or install Airflow from sources. This does not affect the ability of installing Airflow from
released wheel packages.
The 2.9.2 downloads of Apache Airflow® are available at:
Whl package (asc, sha512)
If you want to install from the source code, you can download from the sources link above, it will contain
a INSTALL
file containing details on how you can build and install Airflow.
Release integrity¶
It is essential that you verify the integrity of the downloaded files using the PGP or SHA signatures. The PGP signatures can be verified using GPG or PGP. Please download the KEYS as well as the asc signature files for relevant distribution. It is recommended to get these files from the main distribution directory and not from the mirrors.
gpg -i KEYS
or
pgpk -a KEYS
or
pgp -ka KEYS
To verify the binaries/sources you can download the relevant asc files for it from main distribution directory and follow the below guide.
gpg --verify apache-airflow-********.asc apache-airflow-*********
or
pgpv apache-airflow-********.asc
or
pgp apache-airflow-********.asc
Example:
$ gpg --verify apache-airflow-2.9.2-source.tar.gz.asc apache-airflow-2.9.2-source.tar.gz
gpg: Signature made Sat 11 Sep 12:49:54 2021 BST
gpg: using RSA key CDE15C6E4D3A8EC4ECF4BA4B6674E08AD7DE406F
gpg: issuer "kaxilnaik@apache.org"
gpg: Good signature from "Kaxil Naik <kaxilnaik@apache.org>" [unknown]
gpg: aka "Kaxil Naik <kaxilnaik@gmail.com>" [unknown]
gpg: WARNING: The key's User ID is not certified with a trusted signature!
gpg: There is no indication that the signature belongs to the owner.
Primary key fingerprint: CDE1 5C6E 4D3A 8EC4 ECF4 BA4B 6674 E08A D7DE 406F
The “Good signature from …” is indication that the signatures are correct.
Do not worry about the “not certified with a trusted signature” warning. Most of the certificates used
by release managers are self signed, that’s why you get this warning. By importing the server in the
previous step and importing it via ID from KEYS
page, you know that this is a valid Key already.
For SHA512 sum check, download the relevant sha512
and run the following:
shasum -a 512 apache-airflow--******** | diff - apache-airflow--********.sha512
The SHASUM
of the file should match the one provided in .sha512
file.
Example:
shasum -a 512 apache-airflow-2.9.2-source.tar.gz | diff - apache-airflow-2.9.2-source.tar.gz.sha512
Verifying PyPI releases¶
You can verify the Airflow .whl
packages from PyPI by locally downloading the package and signature
and SHA sum files with the script below:
#!/bin/bash
AIRFLOW_VERSION="2.9.2"
airflow_download_dir="$(mktemp -d)"
pip download --no-deps "apache-airflow==${AIRFLOW_VERSION}" --dest "${airflow_download_dir}"
curl "https://downloads.apache.org/airflow/${AIRFLOW_VERSION}/apache_airflow-${AIRFLOW_VERSION}-py3-none-any.whl.asc" \
-L -o "${airflow_download_dir}/apache_airflow-${AIRFLOW_VERSION}-py3-none-any.whl.asc"
curl "https://downloads.apache.org/airflow/${AIRFLOW_VERSION}/apache_airflow-${AIRFLOW_VERSION}-py3-none-any.whl.sha512" \
-L -o "${airflow_download_dir}/apache_airflow-${AIRFLOW_VERSION}-py3-none-any.whl.sha512"
echo
echo "Please verify files downloaded to ${airflow_download_dir}"
ls -la "${airflow_download_dir}"
echo
Once you verify the files following the instructions from previous chapter you can remove the temporary folder created.