从源代码安装¶
已发布的软件包¶
本页介绍如何使用官方发布的软件包下载和验证 apache-airflow-providers-smtp
提供程序版本 2.0.3
。您也可以像大多数 Python 软件包一样,通过 PyPI 安装提供程序软件包。您可以通过页面左上角的下拉菜单选择不同版本的提供程序。
发布的 sdist
和 whl
软件包是官方的安装来源,如果您想验证软件包的来源并验证校验和和签名,可以使用这些软件包。这些软件包可通过 官方 Apache 软件基金会下载 获取。
下载地址如下:
如果您想从源代码安装,可以从上面的源代码链接下载,它将包含一个 INSTALL
文件,其中包含有关如何构建和安装提供程序的详细信息。
发布完整性¶
您必须使用 PGP 或 SHA 签名验证下载文件的完整性。PGP 签名可以使用 GPG 或 PGP 进行验证。请下载 KEYS 文件以及相关分发版本的 asc 签名文件。建议从主分发目录而不是镜像下载这些文件。
gpg -i KEYS
或
pgpk -a KEYS
或
pgp -ka KEYS
要验证二进制文件/源代码,您可以从主分发目录下载相关的 asc 文件,并按照以下指南进行操作。
gpg --verify apache-airflow-providers-********.asc apache-airflow-*********
或
pgpv apache-airflow-providers-********.asc
或
pgp apache-airflow-providers-********.asc
示例
$ gpg --verify apache-airflow-providers-smtp-2.0.3.tar.gz.asc apache-airflow-providers-smtp-2.0.3.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
“Good signature from …” 表示签名正确。请不用担心“not certified with a trusted signature”警告。发布经理使用的大多数证书都是自签名的,因此会出现此警告。通过上一步导入服务器并通过 KEYS
页面上的 ID 导入它,您就知道这是一个有效的 Key 了。
对于 SHA512 和校验,下载相关的 sha512
文件并运行以下命令:
shasum -a 512 apache-airflow-providers-******** | diff - apache-airflow-providers-********.sha512
文件的 SHASUM
应与 .sha512
文件中提供的一致。
示例
shasum -a 512 apache-airflow-providers-smtp-2.0.3.tar.gz | diff - apache-airflow-providers-smtp-2.0.3.tar.gz.sha512
验证 PyPI 版本¶
您可以通过本地下载软件包以及签名和 SHA 和文件,使用以下脚本验证 PyPI 的 Provider .whl
软件包:
#!/bin/bash
PACKAGE_VERSION=2.0.3
PACKAGE_NAME=apache-airflow-providers-smtp
provider_download_dir=$(mktemp -d)
pip download --no-deps "${PACKAGE_NAME}==${PACKAGE_VERSION}" --dest "${provider_download_dir}"
curl "https://downloads.apache.org/airflow/providers/apache_airflow_providers_smtp-2.0.3-py3-none-any.whl.asc" \
-L -o "${provider_download_dir}/apache_airflow_providers_smtp-2.0.3-py3-none-any.whl.asc"
curl "https://downloads.apache.org/airflow/providers/apache_airflow_providers_smtp-2.0.3-py3-none-any.whl.sha512" \
-L -o "${provider_download_dir}/apache_airflow_providers_smtp-2.0.3-py3-none-any.whl.sha512"
echo
echo "Please verify files downloaded to ${provider_download_dir}"
ls -la "${provider_download_dir}"
echo
按照上一章节的说明验证文件后,您可以删除创建的临时文件夹。