Ansible 集合创建者路径
注意
如果您不熟悉 Ansible 集合,请先查看 使用 Ansible 集合指南。
Ansible 集合是 Ansible 内容的一种分发格式,其中可以包含 playbook、角色、模块和插件。一个典型的集合解决一组相关的用例。例如,community.dns
集合包括用于处理 DNS 的模块和插件。
您可以安装其他人创建的集合,也可以通过分发服务器(例如 Ansible Galaxy)与社区共享您的集合。经过认证的集合可以发布到 Red Hat Automation Hub,它是 Red Hat Ansible Automation Platform 的一部分。
创建和共享集合是为 Ansible 项目做出贡献的好方法。
Ansible 社区软件包由 ansible-core
组成,它除了其他核心组件外,还包括由核心团队维护的 ansible.builtin
集合,以及一组由社区维护的集合。
本指南的目的是为您(潜在的)内容创建者提供一个一致的概述,涵盖 Ansible 集合创建者的整个旅程,从第一个模块/角色的想法到将您的集合包含在 Ansible 社区软件包中。 集合开发指南部分 提供了有关此旅程更详细方面的参考。整个旅程包括以下里程碑
检查当前可用的解决方案
如果您有一个新的角色或模块/插件的想法,如果已经有足够的解决方案可以解决您的自动化问题,则无需重新发明轮子。
因此,首先检查当前可用的内容,包括
Ansible Automation Hub(如果您有 Ansible Automation Platform 订阅)
如果您发现的解决方案不完全足够或存在缺陷,请考虑改进它们,而不是创建自己的解决方案。每个集合都包含有关在何处为该集合创建问题以提出您的增强想法的信息。
如果您已经编写了您的内容并在您的工作流程中使用它,您仍然可以考虑将其集成到现有的解决方案中。但是,如果这些选项不适用于您的集合想法,我们鼓励您创建和共享您自己的集合。
创建你的内容
您 尝试过 但没有找到任何足以解决您的自动化问题的解决方案。
使用以下指南之一
将你的内容放入集合
您 创建了 新内容。
现在是时候创建一个可重用且可共享的集合了。使用 开发集合指南 来学习如何操作。
我们建议您使用 collection_template 存储库 作为您集合的基础。
编写优秀的用户集合文档
您的集合 README.md
文件应包含快速入门安装和使用指南。您可以使用 community.general 集合 README 文件 作为示例。
如果您的集合包含模块或插件,请确保其文档全面。使用 模块格式和文档指南 和 Ansible 文档风格指南 了解更多信息。
发布你的集合源代码
在软件开发和版本控制平台(例如 GitHub)上发布您的集合。
它可以是您的个人存储库或您组织的存储库。您也可以 请求 在 ansible-collections 组织下创建一个存储库。
确保您的集合包含详尽的许可证信息。Ansible 是一个开源项目,因此我们鼓励您在其中一个开源许可证下对其进行许可。如果您计划提交您的集合以将其包含在 Ansible 社区软件包中,则您的集合必须满足 许可证要求。
如果您之前已使用我们推荐的 collection_template 存储库 作为您集合的骨架,则它已经包含 GNU GPL v3
许可证。
遵循版本控制约定
在发布集合的新版本时,请考虑以下建议的实践
了解和实施测试和 CI
此部分适用于包含模块和插件的集合。
有关角色测试,请参阅 Ansible Molecule 项目。
添加测试
测试您的集合可确保您的代码能够正常工作并与其他组件(例如 ansible-core
)集成。
查看以下文档
测试 Ansible 指南:提供有关测试的一般信息。
测试集合指南:包含特定于集合的测试信息。
实施持续集成
现在,确保在您的集合存储库中创建拉取请求时,使用 CI 工具(如 GitHub Actions 或 Azure Pipelines)自动测试它们。
collection_template 存储库 包含 GitHub Actions 模板,您可以调整并使用这些模板来启用存储库中的工作流。
提供良好的贡献者和维护者文档
请参考 collection_template/README.md 作为示例。
在分发服务器上发布您的集合
为了分发您的集合并允许其他人方便地使用它,请在至少一个分发服务器上发布您的集合。请参阅 分发集合指南 以了解如何操作。
将您的集合纳入 Ansible 社区包
请确保您的集合满足 Ansible 社区包集合要求,并提交以供纳入。请参阅 纳入流程说明 以了解如何操作。
维护
维护您的集合。请参阅 Ansible 集合维护者指南 获取详细信息。
沟通
参与社区。请查看 Ansible 沟通指南 以了解可用的沟通选项。
另请参阅
- 开发集合
关于集合开发各个方面的指南