一、需求

   线上机器比较多,之前用excel统计过一次,用ansible批量执行脚本,然后根据展示信息来,手功录入到excel,效率可想而知。其他部门要查看主机信息,无法第一时间提供,所以,就在想,能不能以静态页面展示出来,放在apache的htdoc目录下。后面找到一个ansible-cmdb,很好解决了这个问题!

二、Ansible配置管理数据库

   Ansible-cmdb将收集输出并将其转换成静态HTML概述页面包含系统配置信息,它支持多个模板(html, txt_table, csv, json output, markdown) 和通过自定义数据收集扩展信息,为每个主机显示组,主机变量,找出依据。

三、步聚

1、安装

1
# rpm -ivh ansible-cmdb-1.12-2.noarch.rpm

2、为主机生成输出文件

1
2
#mkdir out
#ansible -m setup --tree out/ all


3、生成CMDB概述页

1
ansible-cmdb -i  /etc/ansible/hosts  out/ > overview.html

 注意了,这个/etc/ansible/hosts,其实,你可自定义的,像我的,是按业务来区分的,如

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[cust.megacorp]
db1.dev.megacorp.com   dtap=dev  comment= "Old database server"
db2.dev.megacorp.com   dtap=dev  comment= "New database server"
test .megacorp.com      dtap= test 
acc.megacorp.com       dtap=acc  comment= "24/7 support"
megacorp.com           dtap=prod comment= "Hosting by Foo"  ext_id= "SRV_10029"
 
[os.redhat]
megacorp.com
acc.megacorp.com
test .megacorp.com
db2.dev.megacorp.com
 
[os.debian]
db1.dev.megacorp.com


4、把overview.html放到apache下htodc目录下

1
# scp ./overview.html /usr/local/apache2/htdocs/zabbix/

  这里,可在第3步,定时crontab执行任务

5、页面展示

wKiom1bmQlXxLykqAARvjwML7yU369.jpg


6、有兴趣,可以下载原码看看