在之前的文章中,我们提到 Ansible 是通过 inventory 文件来管理资产的,但是一般情况下,一个配置管理系统往往会将资产存储在一个软件系统里,这种情况下该如何处理呢?
其实,Ansible Inventory 是包含静态 Inventory
和动态 Inventory
两部分的,静态 Inventory 指的是在文件中指定的主机和组,动态 Inventory 指通过外部脚本获取主机列表,并按照 ansible 所要求的格式返回给 ansilbe 命令的。这部分一般会结合 CMDB 资管系统、云计算平台等获取主机信息。由于主机资源一般会动态的进行增减,而这些系统一般会智能更新。我们可以通过这些工具提供的 API 或者接入库查询等方式返回主机列表。
比如为了结合资产管理系统(CMDB),所以要使用到动态获取 inventory 的方法,这样可以省去配置 ansible 服务端的 hosts,所有的客户端 IP、帐号、密码、端口都可以从 CMDB 中获取到。
只要你的脚本输出格式是满足要求的 JSON,这样就可以成为一个动态的资产生成器。
脚本规约
用于生成 JSON 的脚本对实现语言没有要求,它可以是一个可执行脚本、二进制文件,或者其他任何可以运行文件,但是必须输出为 JSON 格式,同时必须支持两个参数:--list
和 --host <hostname>
。
--list
:用于返回所有的主机组信息,每个组所包含的主机列表hosts
、所含子组列表children
、主机组变量列表vars
都应该是字典形式的,_meta
用来存放主机变量。
示例如下:
{ "group1": { "hosts": [ "192.168.28.71", "192.168.28.72" ], "vars": { "ansible_ssh_user": "johndoe", "ansible_ssh_private_key_file": "~/.ssh/mykey", "example_variable": "value" }, "children":['group2'] }, "_meta": { "hostvars": { "192.168.28.71": { "host_specific_var": "bar" }, "192.168.28.72": { "host_specific_var": "foo" } } } }
--host <hostname>
:返回指定主机的变量列表,或者返回一个空的字典
如:
{ "host_specific_var": "foo"}
脚本实现
一个参考实现框架如下:
#!/usr/bin/env python3#coding:utf8import jsonimport sys def all(): info_dict = { "all":[ "10.10.0.109", "10.10.0.112"] } print(json.dumps(info_dict,indent=4)) def group(): host1 = ['10.10.0.112'] host2 = ['10.10.0.112','10.10.0.109'] group1 = 'test1' group2 = 'test2' hostdata = { group1:{"hosts":host1}, group2:{"hosts":host2} } print(json.dumps(hostdata,indent=4)) def host(ip): info_dict = { "10.10.0.112": { "ansible_ssh_host":"10.10.0.112", "ansible_ssh_port":22, "ansible_ssh_user":"root", "ansible_ssh_pass":"123457" }, "10.10.0.109": { "ansible_ssh_host":"10.10.0.109", "ansible_ssh_port":22, "ansible_ssh_user":"root", "ansible_ssh_pass":"xxxx" } } print(json.dumps(info_dict,indent=4)) if len(sys.argv) == 2 and (sys.argv[1] == '--list'): group()elif len(sys.argv) == 3 and (sys.argv[1] == '--host'): host(sys.argv[2])else: print("Usage: %s --list or --host <hostname>" % sys.argv[0]) sys.exit(1)
使用
使用方法和静态 inventory 类似:
# 可以指定组$ ansible -i dynamic_investory.py all --list-hosts hosts (3): 127.0.0.1 10.10.0.112 10.10.0.109# 可以指定主机$ ansible -i dynamic_investory.py 127.0.0.1 --list-hosts hosts (1): 127.0.0.1
作者:hoxis
链接:https://www.jianshu.com/p/71d6700fbe79
共同学习,写下你的评论
评论加载中...
作者其他优质文章