在Ansible播放中覆盖IP地址或主机标签

时间:2018-06-23 05:14:00

标签: ansible

在我的个人网络上,我有一个简单的主机列表:

[host1]
192.168.1.2
[host2]
192.168.1.10

当我设置本地主机时,说“ host2”,它具有一个随机(dhcp)IP地址。我已经更改了hosts.ini并覆盖了主机IP地址,然后使用host vars将我想要的IP地址实际设置为其dhcpcd.conf。

我的剧本有我所有的本地机器,因此我需要主机标签来匹配。但是如果没有一些手动工作,我无法在首次启动时使用它。

我可以想到一些解决方法:

  1. ansible-playbook命令行上的手动清单中覆盖IP
  2. ansible-playbook命令行上的手动清单中指定主机IP和主机名
  3. ansible-playbook命令行上设置一个可用的主机名

问题是我无法让他们中的任何一个工作

ansible-playbook play.yml -i "[host2]\n192.168.0.123," --limit host2
 [WARNING]: Could not match supplied host pattern, ignoring: host2

ansible-playbook play.yml -i "192.168.0.123 ansible_host=host2," --limit host2
 [WARNING]: Could not match supplied host pattern, ignoring: host2

ansible-playbook play.yml -i "192.168.0.123," -e "ansible_host=host2" --limit host2
 [WARNING]: Could not match supplied host pattern, ignoring: host2

我真的认为第三个想法是有道理的,我只是无法从这里到达那里。由于这是单发类型的问题,因此我不需要创建临时主机文件,但是我不确定另一种方法。

请注意,有一个较早的播放/任务可以调用add_hosts 几乎,但是鉴于在库存中已经存在host2,我要么必须清空库存,要么(以某种方式)致电我的主人只。记住,这是为了引导,所以这个主意是以后避免任何魔术。

很抱歉,我们为此道歉。我想为XY问题提供背景,并询问我的具体策略/问题。

1 个答案:

答案 0 :(得分:2)

为什么不使用基于设备Mac地址的动态清单?

只是一个小例子。当然需要改进,但仅供参考:

#!/usr/bin/env python
# -*- coding:utf-8 -*-
from __future__ import (absolute_import, division, print_function,
                        unicode_literals)

import json
import socket
import subprocess
import re


def main():
    print(json.dumps(inventory(), sort_keys=True, indent=2))


def inventory():
    ip_address = find_ip()

    return {
        'all': {
            'hosts': [ip_address],
            'vars': {},
        },
        '_meta': {
            'hostvars': {
                ip_address: {
                    'ansible_ssh_user': 'ansible',
                }
            },
        },
        'ip': [ip_address]
    }


def find_ip():
    lines = subprocess.check_output(['arp', '-a']).decode('utf-8').split('\n')
    for line in lines:
        if re.search('a0:d7:95:1a:80:f8', line):
            ip = re.search(r"(\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b)", line)
            return ip.group(1)


if __name__ == '__main__':
    main()

输出:

{
  "_meta": {
    "hostvars": {
      "192.168.0.100": {
        "ansible_ssh_user": "ansible"
      }
    }
  },
  "all": {
    "hosts": [
      "192.168.0.100"
    ],
    "vars": {
      "ansible_connection": "local"
    }
  },
  "ip": [
    "192.168.0.100"
  ]
}

示例:

ansible-playbook -i inventories/dynamic/mydyn.py hosts.yml 

PLAY [Test wait] ****************************************************************************************************************

TASK [Debug] ********************************************************************************************************************
ok: [192.168.0.100] => {
    "ansible_host": "192.168.0.100"
}

TASK [Ping] *********************************************************************************************************************
ok: [192.168.0.100]

PLAY RECAP **********************************************************************************************************************
192.168.0.100              : ok=2    changed=0    unreachable=0    failed=0