分发集合
集合是 Ansible 内容的分发格式。一个典型的集合包含模块和其他插件,这些模块和插件解决一组相关的用例。例如,一个集合可能自动化管理特定的数据库。一个集合还可以包含角色和 Playbook。
注意
在分发您的集合之前,请确保您已更新 galaxy.yml
文件。有关详细信息,请参阅 集合结构。
要分发您的集合并允许其他人使用它,您可以将您的集合发布到一个或多个分发服务器。分发服务器包括
分发服务器 |
接受的集合 |
---|---|
Ansible Galaxy |
所有集合 |
所有集合,支持签名集合 |
|
红帽自动化中心 |
仅限红帽认证的集合,支持签名集合 |
私有托管的自动化中心 |
所有者授权的集合 |
分发集合涉及四个主要步骤
您的分发服务器或服务器的初始配置
构建您的集合 tarball
准备发布您的集合
发布您的集合
您的分发服务器或服务器的初始配置
配置与一个或多个分发服务器的连接,以便您可以在那里发布集合。您只需要配置每个分发服务器一次。每次发布新集合或现有集合的新版本时,您都必须重复其他步骤(构建您的集合 tarball、准备发布和发布您的集合)。
在您想要使用的每个分发服务器上创建一个命名空间。
为您想要使用的每个分发服务器获取一个 API 令牌。
为您想要使用的每个分发服务器指定 API 令牌。
创建命名空间
您必须将您的集合上传到每个分发服务器上的命名空间中。如果您有 Ansible Galaxy 的登录名,您的 Ansible Galaxy 用户名通常也是一个 Ansible Galaxy 命名空间。
警告
Ansible Galaxy 上的命名空间不能包含连字符。如果您的 Ansible Galaxy 登录名包含连字符,您的 Galaxy 用户名也不是一个 Galaxy 命名空间。例如,awesome-user
是 Ansible Galaxy 的有效用户名,但它不是一个有效的命名空间。
您可以选择在 Ansible Galaxy 上创建其他命名空间。对于红帽自动化中心和私有自动化中心,您必须先创建一个命名空间才能上传您的集合。要创建命名空间
要在 Galaxy 上创建命名空间,请参阅 Galaxy 文档网站上的 Galaxy 命名空间,了解详细信息。
要在红帽自动化中心上创建命名空间,请参阅红帽自动化内容文档。
在每个集合的 galaxy.yml
文件中指定命名空间。有关 galaxy.yml
文件的更多信息,请参阅集合 Galaxy 元数据结构。
获取您的 API 令牌
API 令牌验证您与每个分发服务器的连接。您需要为每个分发服务器单独的 API 令牌。使用正确的 API 令牌来安全地连接到每个分发服务器并保护您的内容。
要获取您的 API 令牌
指定您的 API 令牌和分发服务器
每次发布集合时,您都必须指定 API 令牌和分发服务器以创建安全连接。您有两个选项可以指定令牌和分发服务器
您可以在配置中配置令牌,作为
ansible.cfg
文件中galaxy_server_list
条目的一部分。使用配置是最安全的选择。您可以在命令行上将令牌作为
ansible-galaxy
命令的参数传递。如果您在命令行上传递令牌,您可以通过使用默认设置或在配置中设置服务器来在命令行上指定服务器。在命令行上传递令牌是不安全的,因为在命令行上键入机密可能会将它们暴露给系统上的其他用户。
在配置中指定令牌和分发服务器
默认情况下,Ansible Galaxy 配置为唯一的分发服务器。您可以通过编辑 ansible.cfg
文件的 galaxy_server_list
部分,添加其他分发服务器并指定您的 API 令牌。这是管理分发服务器身份验证的最安全方法。为每个服务器指定一个 URL 和令牌。例如
[galaxy]
server_list = release_galaxy
[galaxy_server.release_galaxy]
url=https://galaxy.ansible.com/
token=abcdefghijklmnopqrtuvwxyz
您不能将 apt-key
与您的 galaxy_server_list 中定义的任何服务器一起使用。有关完整详细信息,请参阅配置 ansible-galaxy 客户端。
在命令行上指定令牌
您可以使用ansible-galaxy命令的 --token
参数在命令行上指定 API 令牌。在命令行上传递令牌时,有三种方法可以指定分发服务器
使用ansible-galaxy命令的
--server
参数依赖默认值 (https://galaxy.ansible.com)
通过在您的
ansible.cfg
文件中创建 GALAXY_SERVER 设置,在配置中设置服务器
例如
ansible-galaxy collection publish path/to/my_namespace-my_collection-1.0.0.tar.gz --token abcdefghijklmnopqrtuvwxyz
警告
使用 --token
参数是不安全的。在命令行中传递密钥可能会将其暴露给系统上的其他人。
构建您的集合 tarball
配置一个或多个分发服务器后,构建一个集合 tarball。集合 tarball 是已发布的工件,即您上传并供其他用户下载以安装您的集合的对象。要构建集合 tarball,请执行以下操作:
查看您的
galaxy.yml
文件中的所有设置。有关详细信息,请参阅 集合 Galaxy 元数据结构。确保您已更新版本号。每次发布您的集合时,它都必须有一个新的版本号。您不能对分发服务器上集合的现有版本进行更改。如果您尝试多次上传相同的集合版本,分发服务器将返回错误Code: conflict.collection_exists
。集合遵循语义版本控制规则。有关版本的更多信息,请参阅 了解集合版本控制。有关galaxy.yml
文件的更多信息,请参阅 集合 Galaxy 元数据结构。从集合的顶层目录内运行
ansible-galaxy collection build
。例如:
collection_dir#> ansible-galaxy collection build
此命令会在当前目录中构建集合的 tarball,您可以将其上传到您选择的分发服务器
my_collection/
├── galaxy.yml
├── ...
├── my_namespace-my_collection-1.0.0.tar.gz
└── ...
注意
为了减小集合的大小,默认情况下,某些文件和文件夹将从集合 tarball 中排除。如果您的集合目录包含您要排除的其他文件,请参阅 忽略文件和文件夹。
当前 Galaxy 的最大 tarball 大小为 2 MB。
您可以将您的 tarball 上传到一个或多个分发服务器。您还可以通过将 tarball 复制到目标系统上直接安装集合,从而在本地分发您的集合。
忽略文件和文件夹
您可以使用 build_ignore 或 Manifest 指令 从您的集合中排除文件。有关 galaxy.yml
文件的更多信息,请参阅 集合 Galaxy 元数据结构。
包含所有,显式忽略
默认情况下,构建步骤会将集合目录中的所有文件都包含在 tarball 中,但以下文件除外:
galaxy.yml
*.pyc
*.retry
tests/output
根目录中之前构建的 tarball
各种版本控制目录,例如
.git/
要从您的集合 tarball 中排除其他文件和文件夹,请在集合的 galaxy.yml
文件中的 build_ignore
键中设置一个类似文件 glob 模式的列表。这些模式使用以下特殊字符进行通配符匹配:
*
: 匹配所有内容?
: 匹配任意单个字符[seq]
: 匹配序列中的任意字符[!seq]
: 匹配序列中不存在的任意字符
例如,要排除 playbooks
文件夹中的 sensitive
文件夹以及任何 .tar.gz
存档,请在您的 galaxy.yml
文件中设置以下内容:
build_ignore:
- playbooks/sensitive
- '*.tar.gz'
注意
只有在 Ansible 2.10 或更高版本中,才支持 ansible-galaxy collection build
的 build_ignore
功能。
Manifest 指令
2.14 版本中新增。
galaxy.yml
文件支持在 Python 打包中使用的 manifest 指令,如 MANIFEST.in 命令中所述。
注意
使用 manifest
需要安装可选的 distlib
Python 依赖项。
注意
只有在 ansible-core
2.14 或更高版本中,ansible-galaxy collection build
才支持 manifest
功能,并且与 build_ignore
互斥。
例如,要排除 playbooks
文件夹中的 sensitive
文件夹以及任何 .tar.gz
存档,请在您的 galaxy.yml
文件中设置以下内容:
manifest:
directives:
- recursive-exclude playbooks/sensitive **
- global-exclude *.tar.gz
默认情况下,MANIFEST.in
样式指令默认会排除所有文件,但有一些默认指令到位。下面介绍了这些默认指令。要查看构建期间使用的指令,请将 -vvv
与 ansible-galaxy collection build
命令一起传递。
include meta/*.yml
include *.txt *.md *.rst COPYING LICENSE
recursive-include tests **
recursive-include docs **.rst **.yml **.yaml **.json **.j2 **.txt
recursive-include roles **.yml **.yaml **.json **.j2
recursive-include playbooks **.yml **.yaml **.json
recursive-include changelogs **.yml **.yaml
recursive-include plugins */**.py
recursive-include plugins/become **.yml **.yaml
recursive-include plugins/cache **.yml **.yaml
recursive-include plugins/callback **.yml **.yaml
recursive-include plugins/cliconf **.yml **.yaml
recursive-include plugins/connection **.yml **.yaml
recursive-include plugins/filter **.yml **.yaml
recursive-include plugins/httpapi **.yml **.yaml
recursive-include plugins/inventory **.yml **.yaml
recursive-include plugins/lookup **.yml **.yaml
recursive-include plugins/netconf **.yml **.yaml
recursive-include plugins/shell **.yml **.yaml
recursive-include plugins/strategy **.yml **.yaml
recursive-include plugins/test **.yml **.yaml
recursive-include plugins/vars **.yml **.yaml
recursive-include plugins/modules **.ps1 **.yml **.yaml
recursive-include plugins/module_utils **.ps1 **.psm1 **.cs
# manifest.directives from galaxy.yml inserted here
exclude galaxy.yml galaxy.yaml MANIFEST.json FILES.json <namespace>-<name>-*.tar.gz
recursive-exclude tests/output **
global-exclude /.* /__pycache__
注意
<namespace>-<name>-*.tar.gz
会使用实际的 namespace
和 name
展开。
在 galaxy.yml
中提供的 manifest.directives
会在默认包含之后和默认排除之前插入。
要启用 manifest 指令的使用而不提供自己的指令,请在 galaxy.yml
文件中插入 manifest: {}
或 manifest: null
,并删除任何对 build_ignore
的使用。
如果默认 manifest 指令不能满足您的需求,您可以在 galaxy.yml
中将 manifest.omit_default_directives
的值设置为 true
。然后,您必须在 galaxy.yml
中指定完整的 manifest 指令。上面记录的默认值是一个很好的起点。
以下示例说明了未包含默认指令的情况。
manifest:
directives:
- include meta/runtime.yml
- include README.md LICENSE
- recursive-include plugins */**.py
- exclude galaxy.yml MANIFEST.json FILES.json <namespace>-<name>-*.tar.gz
- recursive-exclude tests/output **
omit_default_directives: true
对集合进行签名
您可以在 Pulp 3 Galaxy 服务器上为您的集合包含 GnuPG 签名。有关详细信息,请参阅 启用集合签名。
您可以使用以下步骤使用 gpg
CLI 手动为集合生成分离签名。此步骤假设您已生成 GPG 私钥,但不涵盖此过程。
ansible-galaxy collection build
tar -Oxzf namespace-name-1.0.0.tar.gz MANIFEST.json | gpg --output namespace-name-1.0.0.asc --detach-sign --armor --local-user [email protected] -
准备发布您的集合
每次发布您的集合时,您都必须在分发服务器上创建一个新版本。发布集合版本后,您无法删除或修改该版本。为了避免不必要的额外版本,请在发布之前在本地检查您的集合是否存在错误、错别字和其他问题。
在本地安装集合。
在发布新版本之前,检查本地安装的集合。
在本地安装您的集合
您有两种在本地安装集合的选项:
从 tarball 在本地安装您的集合。
从您的 Git 存储库在本地安装您的集合。
从 tarball 在本地安装您的集合
要从 tarball 在本地安装您的集合,请运行 ansible-galaxy collection install
并指定集合 tarball。您可以选择使用 -p
标志指定位置。例如:
collection_dir#> ansible-galaxy collection install my_namespace-my_collection-1.0.0.tar.gz -p ./collections
将 tarball 安装到 COLLECTIONS_PATHS 中配置的目录中,以便 Ansible 可以轻松找到并加载集合。如果您不指定路径值,ansible-galaxy collection install
会将集合安装在 COLLECTIONS_PATHS 中定义的第一个路径中。
从 Git 存储库在本地安装您的集合
要从 Git 存储库在本地安装您的集合,请指定您要安装的存储库和分支
collection_dir#> ansible-galaxy collection install git+https://github.com/org/repo.git,devel
您可以从 Git 存储库而不是从 Galaxy 或 Automation Hub 安装集合。作为开发人员,从 Git 存储库安装可以让您在创建 tarball 并发布集合之前检查您的集合。作为用户,从 Git 存储库安装可以让您使用 Galaxy 或 Automation Hub 中尚未提供的集合或版本。此功能旨在作为之前描述的内容开发人员的最小快捷方式,并且 Git 存储库可能不支持 ansible-galaxy
CLI 的全部功能。在复杂情况下,更灵活的选择可能是将存储库 git clone
到集合安装目录的正确文件结构中。
存储库必须包含 galaxy.yml
或 MANIFEST.json
文件。此文件提供元数据,例如集合的版本号和命名空间。
从命令行从 Git 存储库安装集合
要从命令行从 Git 存储库安装集合,请使用存储库的 URI 而不是集合名称或 tar.gz
文件的路径。使用前缀 git+
,除非您使用用户 git
进行 SSH 身份验证(例如,[email protected]:ansible-collections/ansible.windows.git
)。您可以使用逗号分隔的 git commit-ish 语法指定分支、提交或标记。
例如
# Install a collection in a repository using the latest commit on the branch 'devel'
ansible-galaxy collection install git+https://github.com/organization/repo_name.git,devel
# Install a collection from a private GitHub repository
ansible-galaxy collection install [email protected]:organization/repo_name.git
# Install a collection from a local git repository
ansible-galaxy collection install git+file:///home/user/path/to/repo_name.git
警告
将凭据嵌入到 git URI 中是不安全的。请使用安全的身份验证选项,以防止您的凭据在日志或其他地方暴露。
使用 SSH 身份验证
使用 netrc 身份验证
在您的 git 配置中使用 http.extraHeader
在您的 git 配置中使用 url.<base>.pushInsteadOf
指定 git 仓库中的集合位置
当您从 git 仓库安装集合时,Ansible 会使用集合的 galaxy.yml
或 MANIFEST.json
元数据文件来构建集合。默认情况下,Ansible 会在两个路径中搜索集合的 galaxy.yml
或 MANIFEST.json
元数据文件
仓库的顶层。
仓库路径中的每个目录(深度为一层)。
如果仓库的顶层存在 galaxy.yml
或 MANIFEST.json
文件,Ansible 将使用该文件中的集合元数据来安装单个集合。
├── galaxy.yml
├── plugins/
│ ├── lookup/
│ ├── modules/
│ └── module_utils/
└─── README.md
如果仓库路径中的一个或多个目录(深度为一层)中存在 galaxy.yml
或 MANIFEST.json
文件,Ansible 会将每个具有元数据文件的目录安装为一个集合。例如,默认情况下,Ansible 会从此仓库结构安装 collection1 和 collection2
├── collection1
│ ├── docs/
│ ├── galaxy.yml
│ └── plugins/
│ ├── inventory/
│ └── modules/
└── collection2
├── docs/
├── galaxy.yml
├── plugins/
| ├── filter/
| └── modules/
└── roles/
如果您有不同的仓库结构,或者只想安装集合的子集,则可以在 URI 的末尾添加一个片段(在可选的逗号分隔版本之前),以指示元数据文件或文件的位置。该路径应为一个目录,而不是元数据文件本身。例如,要仅从具有两个集合的示例仓库中安装 collection2
ansible-galaxy collection install git+https://github.com/organization/repo_name.git#/collection2/
在某些仓库中,主目录对应于命名空间
namespace/
├── collectionA/
| ├── docs/
| ├── galaxy.yml
| ├── plugins/
| │ ├── README.md
| │ └── modules/
| ├── README.md
| └── roles/
└── collectionB/
├── docs/
├── galaxy.yml
├── plugins/
│ ├── connection/
│ └── modules/
├── README.md
└── roles/
您可以安装此仓库中的所有集合,或从特定提交安装一个集合
# Install all collections in the namespace
ansible-galaxy collection install git+https://github.com/organization/repo_name.git#/namespace/
# Install an individual collection using a specific commit
ansible-galaxy collection install git+https://github.com/organization/repo_name.git#/namespace/collectionA/,7b60ddc245bc416b72d8ea6ed7b799885110f5e5
审查您的集合
审查集合
运行一个使用您的集合中的模块和插件的 playbook。验证新特性和功能是否按预期工作。有关示例和更多详细信息,请参阅 使用集合。
检查文档中是否有错别字。
检查您的 tarball 的版本号是否高于分发服务器上最新的已发布版本。
如果您发现任何问题,请修复它们并重新构建集合 tarball。
理解集合版本控制
更改集合的唯一方法是发布新版本。集合的最新版本(按最高版本号)是在 Galaxy 和 Automation Hub 中到处显示的版本。用户仍然可以下载旧版本。
在设置您的集合版本时,请遵循语义版本控制。总结来说
对于不兼容的 API 更改,请递增
x.y.z
的主要版本号x
。对于以向后兼容的方式添加的新功能(例如,新的模块/插件、参数、返回值),请递增
x.y.z
的次要版本号y
。对于向后兼容的错误修复,请递增
x.y.z
的补丁版本号z
。
有关详细信息和示例,请阅读官方 语义版本控制 文档。
发布您的集合
分发您的集合的最后一步是将 tarball 发布到 Ansible Galaxy、Red Hat Automation Hub 或私有托管的 Automation Hub 实例。您可以通过两种方式发布您的集合
从命令行使用
ansible-galaxy collection publish
命令从分发服务器(Galaxy、Automation Hub)的网站本身发布
从命令行发布集合
要从命令行使用 ansible-galaxy
上传集合 tarball
ansible-galaxy collection publish path/to/my_namespace-my_collection-1.0.0.tar.gz
注意
此 ansible-galaxy 命令假设您已检索并将您的 API 令牌存储在配置中。有关详细信息,请参阅 指定您的 API 令牌和分发服务器。
ansible-galaxy collection publish
命令会触发一个导入过程,就像您通过 Galaxy 网站上传集合一样。该命令会等待导入过程完成,然后再报告状态。如果您想在不等待导入结果的情况下继续,请使用 --no-wait
参数,并手动查看您的 我的导入 页面中的导入进度。
从网站发布集合
请参阅 Galaxy 文档,了解如何在 Galaxy 网站上直接发布您的集合。
另请参阅
- 使用 Ansible 集合
了解如何安装和使用集合。
- 集合 Galaxy 元数据结构
galaxy.yml
文件中使用的字段表- 沟通
有疑问?需要帮助?想分享您的想法?请访问 Ansible 沟通指南