Httpapi 插件

Httpapi 插件告诉 Ansible 如何与远程设备的基于 HTTP 的 API 交互并在设备上执行任务。

每个插件都代表 API 的特定方言。有些是特定于平台的(Arista eAPI、Cisco NXAPI),而其他一些则可以在各种平台上使用(RESTCONF)。Ansible 会根据ansible_network_os变量自动加载相应的 httpapi 插件。

添加 httpapi 插件

您可以通过将自定义插件放入httpapi_plugins目录来扩展 Ansible 以支持其他 API。有关详细信息,请参见开发 httpapi 插件

使用 httpapi 插件

要使用的 httpapi 插件将根据ansible_network_os变量自动确定。

大多数 httpapi 插件无需配置即可运行。每个插件都可以定义其他选项。

插件是自文档化的。每个插件都应该记录其配置选项。

以下示例剧本显示了 Arista 网络设备的 httpapi 插件,假设清单变量设置为ansible_network_os=eos,以便 httpapi 插件触发。

- hosts: leaf01
  connection: httpapi
  gather_facts: false
  tasks:

    - name: type a simple arista command
      eos_command:
        commands:
          - show version | json
      register: command_output

    - name: print command output to terminal window
      debug:
        var: command_output.stdout[0]["version"]

请参阅 GitHub 上的完整工作示例

查看 httpapi 插件

这些插件已迁移到 Ansible Galaxy 上的集合。如果您使用 pip 安装了 Ansible 2.10 或更高版本,则可以访问多个 httpapi 插件。您可以使用 ansible-doc -t httpapi -l 查看可用插件列表。使用 ansible-doc -t httpapi <plugin name> 查看特定于插件的文档和示例。

另请参阅

用于网络自动化的 Ansible

使用 Ansible 自动化网络设备的概述。

开发网络模块

如何开发网络模块。

沟通

有问题?需要帮助?想分享您的想法?请访问 Ansible 沟通指南