我正在尝试为 Ansible 设置动态清单以与 Azure 一起使用,但我收到一些消息,因为 Ansible 无法解析我的 yaml 文件。
到目前为止我做了什么:
创建 Azure 服务主体并向 /home/user/.azure/credentials 添加凭据(我知道他们建议将它们放在 /home/.azure/credentials 中,我尝试过,但似乎我的 Ansible 在 /home 中查找它们/用户目录。
我将 python 插件(原始的、未编辑的插件)及其 yaml 配置文件放在 /etc/ansible/inventory_plugins 中。配置文件如下所示:
plugin: azure_rm
include_vm_resource_groups:
- vm_1197_rg
auth_source: auto
- 使用以下命令测试功能: ansible all -m ping -i ./myazure_rm.yml
输出:
ansible 2.8.1 配置文件 = /etc/ansible/ansible.cfg 配置模块搜索路径 = [u'/root/.ansible/plugins/modules', u'/usr/share/ansible/plugins/modules'] ansible python模块位置 = /usr/lib/python2.7/site-packages/ansible 可执行位置 = /bin/ansible python 版本 = 2.7.5(默认,2019 年 4 月 9 日,14:30:50)[GCC 4.8.5 20150623( Red Hat 4.8.5-36)] 使用 /etc/ansible/ansible.cfg 作为配置文件 由于库存源不存在或当前用户无法读取而跳过 azure_rm 拒绝将 /etc/ansible/inventory_plugins/myazure_rm.yml 解析为它没有通过它的 verify_file() 方法 [警告]: Unable to parse /etc/ansible/inventory_plugins/myazure_rm.yml 作为库存源
[警告]:没有解析库存,只有隐式本地主机可用
[警告]:提供的主机列表为空,只有 localhost 可用。请注意,隐式本地主机不匹配“全部”