RouterOS 平台选项

RouterOS 是 community.network 集合的一部分,仅支持 CLI 连接和直接 API 访问。本页详细介绍了如何在 Ansible 中对 RouterOS 使用 ansible.netcommon.network_cli。更多信息请参阅community.routeros 集合的 SSH 指南

有关如何使用 RouterOS API 的信息,请参阅community.routeros 集合的 API 指南

可用连接

CLI

协议

SSH

凭据

如果存在,则使用 SSH 密钥/SSH 代理

如果使用密码,则接受 -u myuser -k

间接访问

通过堡垒机(跳转主机)

连接设置

ansible_connection: ansible.network.network_cli

启用模式
(权限提升)

RouterOS 不支持

返回数据格式

stdout[0].

RouterOS SSH 模块不支持 ansible_connection: local。您必须使用 ansible_connection: ansible.netcommon.network_cli

RouterOS API 模块需要 ansible_connection: local。有关更多信息,请参阅community.routeros 集合的 API 指南

在 Ansible 中使用 CLI

CLI 示例 group_vars/routeros.yml

ansible_connection: ansible.netcommon.network_cli
ansible_network_os: community.network.routeros
ansible_user: myuser
ansible_password: !vault...
ansible_become: true
ansible_become_method: enable
ansible_become_password: !vault...
ansible_ssh_common_args: '-o ProxyCommand="ssh -W %h:%p -q bastion01"'
  • 如果您正在使用 SSH 密钥(包括 ssh-agent),则可以删除 ansible_password 配置。

  • 如果您直接访问主机(而不是通过堡垒机/跳转主机),则可以删除 ansible_ssh_common_args 配置。

  • 如果您通过堡垒机/跳转主机访问主机,则不能在 ProxyCommand 指令中包含 SSH 密码。为了防止泄露秘密(例如在 ps 输出中),SSH 不支持通过环境变量提供密码。

  • 如果您遇到超时错误,您可能需要将 +cet1024w 后缀添加到您的用户名,这将禁用控制台颜色,启用“哑”模式,告诉 RouterOS 不要尝试检测终端功能,并将终端宽度设置为 1024 列。有关更多信息,请参阅 MikroTik wiki 中的控制台登录过程

  • 更多说明请参阅 community.routeros 集合的 SSH 指南

CLI 任务示例

- name: Display resource statistics (routeros)
  community.network.routeros_command:
    commands: /system resource print
  register: routeros_resources
  when: ansible_network_os == 'community.network.routeros'

警告

切勿以明文形式存储密码。我们建议使用 SSH 密钥来验证 SSH 连接。Ansible 支持 ssh-agent 来管理您的 SSH 密钥。如果必须使用密码来验证 SSH 连接,我们建议使用 Ansible Vault 对其进行加密。

另请参阅

设置超时选项