您应该开发模块吗?
开发 Ansible 模块很容易,但通常没有必要。在开始编写新的模块之前,请询问
是否已经存在类似的模块?
现有的模块可能涵盖您想要的功能。Ansible 集合包含数千个模块。搜索我们的 包含的集合列表 或 Ansible Galaxy 查看现有的模块是否满足您的需求。
您应该使用还是开发动作插件而不是模块?
动作插件可能是获取所需功能的最佳方式。动作插件在控制节点而不是在受管节点上运行,其功能可供所有模块使用。有关开发插件的更多信息,请阅读 开发插件页面.
您应该使用角色而不是模块吗?
现有模块的组合可能涵盖您想要的功能。您可以为此类用例编写角色。查看 角色文档.
您应该创建集合而不是单个模块吗?
您想要的功能可能太大而无法容纳在单个模块中。如果您想将 Ansible 连接到新的云提供商、数据库或网络平台,您可能需要 开发新的集合.
每个模块都应该具有简洁且定义明确的功能。基本上,遵循 UNIX 的“做好一件事”哲学。
模块不应该要求用户了解要使用的 API/工具的所有底层选项。例如,如果必需的模块参数的合法值无法记录,则表示该模块将被拒绝。
模块通常应该包含与资源交互的大部分逻辑。围绕 API 的轻量级包装器不包含太多逻辑,可能会导致用户将太多逻辑卸载到剧本中,因此该模块将被拒绝。相反,尝试为与 API 的较小独立部分交互创建多个模块。
如果您的用例没有被现有模块、动作插件或角色覆盖,并且您不需要创建多个模块,那么您就可以开始开发新的模块了。从以下主题中选择下一步
我想 开始一个新的模块.
我想查看 开发良好模块的技巧和约定.
我想 编写一个 Windows 模块.
我想 概述 Ansible 的架构.
我想 记录我的模块.
我想 向我的模块添加单元测试和集成测试.
我想 编写多个模块.