找回密码
 注册
查看: 438|回复: 0

ansible-cmdb 获取数据

[复制链接]

1

主题

0

回帖

12

积分

管理员

积分
12
QQ
发表于 2023-3-27 18:02:15 | 显示全部楼层 |阅读模式
ansible-cmdb 获取Ansible facts数据的输出,并将其转换为包含系统配置信息的静态HTML概述页面(及其他内容)。
, L0 W1 Q% b. Q" A( G; U
安装

- d1 P+ {! e" N7 n; z5 W* Z
yum -y install python-pip
0 ^. Y( Y: {" d  O7 K. r; e
pip install ansible-cmdb
使用
生成所有主机得facts信息
$ _9 r: a' q) h+ d+ B  e! u. y

' u4 c* u2 z( T; b) i
ansible -m setup --tree out/ all
生成web页面
9 D. r& d2 L( u7 U3 p2 c

7 R7 v2 E/ T0 v' K+ |) D% ~) m
ansible-cmdb out/ > overview.html
8 l5 b) W6 R5 w, E, C; q

2 `5 V% A' R- k
如果facts用了本地缓存,-f 指定缓存目录即可。

3 V! O/ B3 Q9 J" }8 S4 \
+ {* a6 T  S2 D. P/ j
ansible-cmdb -f /path/to/facts/dir > overview.html
以资产列表得形式统计出ansible主机信息。

' h( q- d( R) Z6 m. ?
& T) C3 h) C' d* |- X1 n
# ansible-cmdb -t txt_table --columns name,os,ip,mem,cpus out/
Name       OS          IP              Mem  CPUs  
---------  ----------  --------------  ---  ----  
localhost  CentOS 7.6  192.168.77.130  1g   1  
输出csv格式的主机信息。

6 T$ {* S1 k4 W2 |: o5 k8 ?- J  f, s9 m; Z
# ansible-cmdb -t csv out/            
"Name","OS","IP","Arch","Mem","MemFree","MemUsed","CPUs","Virt","Disk avail"
"localhost","CentOS 7.6","192.168.77.130","x86_64/x86_64","1g","0g","1g","1","VMware/guest","28.0g, 0.0g"
输出sql文件,导入数据到mysql或者SQLite。
% _* S' y' H9 Z6 r5 _
; l" e, E2 o/ M$ T0 |+ ~0 V. v7 p6 Z
# ansible-cmdb -t sql out/
DROP TABLE IF EXISTS hosts;
CREATE TABLE hosts (
    name VARCHAR(255),
    fqdn VARCHAR(255),
    main_ip VARCHAR(15),
    os_name VARCHAR(80),
    os_version VARCHAR(40),
    system VARCHAR(40),
    kernel VARCHAR(40),
    arch_hardware VARCHAR(12),
    arch_userspace VARCHAR(12),
    virt_type VARCHAR(20),
    virt_role VARCHAR(20),
    cpu_type VARCHAR(60),
    vcpus INT,
    ram FLOAT,
    disk_total FLOAT,
    disk_free FLOAT
);
: `" J: B  K# e7 [( L5 w
    INSERT INTO hosts (
        name,
        fqdn,
        main_ip,
        os_name,
        os_version,
        system,
        kernel,
        arch_hardware,
        arch_userspace,
        virt_type,
        virt_role,
        cpu_type,
        vcpus,
        ram,
        disk_total,
        disk_free
    ) VALUES (
        "localhost",
        "a23-202-231-167.deploy.static.akamaitechnologies.com",
        "192.168.77.130",
        "CentOS",
        "7.6",
        "Linux",
        "5.1.11-1.el7.elrepo.x86_64",
        "x86_64",
        "x86_64",
        "VMware",
        "guest",
        "Intel(R) Core(TM) i3-4160 CPU @ 3.60GHz",
        1,
        0.9,
        29.8,
        27.4
    );
其他模板格式。

2 c$ l& r* l. O# D( k' K* ^# t& q" P  I. i0 g" z
ansible-cmdb -t json out/
ansible-cmdb -t markdown out/
您需要登录后才可以回帖 登录 | 注册

本版积分规则

返回首页|Archiver|手机版|小黑屋|易陆发现技术论坛 ( 蜀ICP备2026014127号-1 )

GMT+8, 2026-6-12 01:46 , Processed in 0.021309 second(s), 23 queries .

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表