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

ansible-cmdb 获取数据

[复制链接]

1

主题

0

回帖

12

积分

管理员

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

- K2 u* m# h, @  R8 k' ]' R% `
安装

- e6 h: {& O  U
yum -y install python-pip
! i: ^8 u- |' z& M4 d4 ^9 ^
pip install ansible-cmdb
使用
生成所有主机得facts信息

3 y  z; ~9 b# X- u  A3 o, l$ l4 i* o9 M: c" t2 B' C
ansible -m setup --tree out/ all
生成web页面
6 [/ s  l0 k) m( e0 [5 i# p$ H

. `3 d# l2 d1 n+ u0 A9 C% |8 ]8 _' S. E
ansible-cmdb out/ > overview.html

+ u8 }6 O; L- W$ B: v
# L5 k9 I5 n% S2 j
如果facts用了本地缓存,-f 指定缓存目录即可。

' ]9 `9 D* N2 K8 A3 m
' Q* E) }& |% t
ansible-cmdb -f /path/to/facts/dir > overview.html
以资产列表得形式统计出ansible主机信息。

; l  }4 f2 u$ w$ V- ~6 S0 Q  F. i% I( Z0 A0 w
# 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格式的主机信息。

+ T2 ~# \. U/ w/ b( Z- K2 G
8 r* h- I6 b' f1 F/ U4 Z: W8 p! |
# 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。

: o- ?/ F  v4 I5 U) Q( q5 L. k  S: P3 o+ F  q
# 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
);
. B1 ?5 u/ R- ~4 h" C4 U+ ^
    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
    );
其他模板格式。
% |/ d. M1 c# \, K0 t; @
: {. @8 t* b( a
ansible-cmdb -t json out/
ansible-cmdb -t markdown out/
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-12 00:42 , Processed in 0.018503 second(s), 22 queries .

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

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