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

ansible-cmdb 获取数据

[复制链接]

1

主题

0

回帖

12

积分

管理员

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

$ }& A. P( P) [; D; W
安装
  N4 R0 D5 q* Z1 y) Z8 f
yum -y install python-pip
! T2 b1 C* Q3 a& P0 |! M
pip install ansible-cmdb
使用
生成所有主机得facts信息

& j! o( X1 F5 C7 x  X- p* s. p4 g& r) x
ansible -m setup --tree out/ all
生成web页面

& M9 I$ e# g) R& j& W% K- v) I
% x3 K6 ^, r2 Y7 j
ansible-cmdb out/ > overview.html

( }6 q7 t* s" T, [2 j; d% x
. {; J$ L# p9 Y
如果facts用了本地缓存,-f 指定缓存目录即可。
, _/ q1 @: S' D$ @9 R

1 X: g+ @' _# J$ |: S
ansible-cmdb -f /path/to/facts/dir > overview.html
以资产列表得形式统计出ansible主机信息。
5 ]% M5 c) f, j" E- @" [. l8 V7 Z, W
  A& m2 O' p# c/ a' o# |. 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格式的主机信息。
7 j, z; h( g3 R( q' N1 f+ H1 I

0 Q$ d9 ~# T% m7 s  f3 Y: \, ~
# 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。
' c& W. I; Z) n- K

% D; e( Q4 j5 f2 }
# 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
);
( ~& Y7 k( G& e$ g. F
    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
    );
其他模板格式。

1 t. r: l7 X& Q! `5 `% d1 B3 Y3 H2 v3 G+ ?6 e' r
ansible-cmdb -t json out/
ansible-cmdb -t markdown out/
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2026-6-12 00:48 , Processed in 0.016766 second(s), 23 queries .

Powered by Discuz! X5.0

© 2001-2026 Discuz! Team.

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