从源代码安装

已发布的软件包

本页面介绍如何使用官方发布的软件包下载和验证 apache-airflow-providers-common-messaging 提供者软件包的 1.0.0 版本。你也可以通过 PyPI 安装此提供者软件包,就像安装大多数 Python 软件包一样。你可以通过页面左上角的下拉菜单选择提供者软件包的不同版本。

发布的 sdistwhl 软件包是你可以用来验证软件包来源、校验和和签名的“官方”安装源。这些软件包可以通过 Apache 软件基金会官方下载网站获取。

可用的下载链接如下:

如果你想从源代码安装,可以从上面的源代码链接下载,其中包含一个 INSTALL 文件,详细说明了如何构建和安装提供者软件包。

发布完整性

PGP 签名 KEYS

验证下载文件(使用 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-common-messaging-1.0.0.tar.gz.asc apache-airflow-providers-common-messaging-1.0.0.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-common-messaging-1.0.0.tar.gz  | diff - apache-airflow-providers-common-messaging-1.0.0.tar.gz.sha512

验证 PyPI 版本

你可以通过本地下载软件包、签名文件和 SHA 和校验文件,使用以下脚本来验证 PyPI 上的提供者 .whl 软件包。

#!/bin/bash
PACKAGE_VERSION=1.0.0
PACKAGE_NAME=apache-airflow-providers-common-messaging
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_common_messaging-1.0.0-py3-none-any.whl.asc" \
    -L -o "${provider_download_dir}/apache_airflow_providers_common_messaging-1.0.0-py3-none-any.whl.asc"
curl "https://downloads.apache.org/airflow/providers/apache_airflow_providers_common_messaging-1.0.0-py3-none-any.whl.sha512" \
    -L -o "${provider_download_dir}/apache_airflow_providers_common_messaging-1.0.0-py3-none-any.whl.sha512"
echo
echo "Please verify files downloaded to ${provider_download_dir}"
ls -la "${provider_download_dir}"
echo

按照上一章的说明验证文件后,可以删除创建的临时文件夹。

这篇文章有帮助吗?