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

ansible-cmdb 获取数据

[复制链接]

1

主题

0

回帖

12

积分

管理员

积分
12
QQ
发表于 2023-3-27 18:02:15 | 显示全部楼层 |阅读模式
ansible-cmdb 获取Ansible facts数据的输出,并将其转换为包含系统配置信息的静态HTML概述页面(及其他内容)。
1 F4 b, D% F$ {, B, r* H" z. v
安装

. ]. e7 a$ a7 y- a7 o
yum -y install python-pip

& ^0 F, _# _2 j+ j
pip install ansible-cmdb
使用
生成所有主机得facts信息

5 j; C+ P* \/ E+ K  R! j2 q0 R2 D# ^
ansible -m setup --tree out/ all
生成web页面
' ~1 d1 z3 q( t' U" A

" L, u+ R8 J) R) |0 w& _# v8 f
ansible-cmdb out/ > overview.html
, c# }, P. @$ X3 e# z# Q

8 p4 w2 H- }$ R. m: K. |
如果facts用了本地缓存,-f 指定缓存目录即可。
7 o5 X4 o! y( B

# }+ s7 b* ~( \8 [; Q  s: f( [
ansible-cmdb -f /path/to/facts/dir > overview.html
以资产列表得形式统计出ansible主机信息。
7 G/ Z8 g. P1 D, C, N
( A8 D- W/ ~( B9 n& _2 o
# 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格式的主机信息。
, t& [6 S6 L  ?; L
' u# U% Q( O, p- z3 y1 A: `
# 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。

3 K/ E) k+ J' r- d! w# N- z7 y+ g3 j; j: v$ m2 n
# 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
);
# \* P" R! x$ j2 S
    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
    );
其他模板格式。
7 U; r/ Z! @8 Y' t

+ |3 H% Q5 l( H/ H9 ^# h. V; N5 @; t
ansible-cmdb -t json out/
ansible-cmdb -t markdown out/
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-12 03:05 , Processed in 0.044144 second(s), 23 queries .

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

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