day114-django_CMDB系统开发三

CMDB系统开发三

一、资产主机模块

1、资产主机模型设计

主机展示信息表

常规性的收集:

主机模型:IP地址、连接端口、操作系统(Linux,Windows,Mac)、机器类型(虚拟机,物理机)、主机名、CPU型号、CPU物理个数、内存信息、系统平台、系统平台位数、UUID、SN、探测状态、创建主机时间、更新主机时间

还要收集硬盘信息,网卡信息,注意一台主机,硬盘可能有多个,网卡也会有多个。所以要单独把硬盘和网卡各单独设计成一张表,然后使用多对一跟主机模型连接起来。

硬盘模型:硬盘名、硬盘大小、外键关联(server)

网卡模型:网卡名、ip地址、外键关联(server)

还需要一张探测表,把探测时候的一些信息记录下来,比如在探测的时候,要输入主机IP,端口,要把这些信息收集下来,并且跟主机表进行关联。

①创建模型

在这里插入图片描述

server_auto暂时不使用注释掉

在这里插入图片描述在这里插入图片描述

django2.0以上ForeignKey需要加参on_delete=models.CASCADE

②迁移数据库

在这里插入图片描述

2、资产主机展示列表

路由

在这里插入图片描述

视图

在这里插入图片描述

模板

在这里插入图片描述

在这里插入图片描述

没有数据,后期通过检查脚本推送服务器的信息到cmdb系统中,然后就添加到资产主机数据表中。

3、资产主机探测功能设计

常规的信息收集,有两种方式,一种是主动采集,一种是客户端收集。

主动探测:一般是通过,SNMP/SSH/TELNET等手段进行远程收集。

在这里插入图片描述

客户端采集:需要在每一个要部署的主机中部署一个客户端进行数据采集并且发送到远程服务端进行接收。

在这里插入图片描述

Tip:升级安装Linux平台Python版本3以上

注意:本安装需要使用到CentOS base源 epel源

#!/bin/bash
yum install -y openssl-devel bzip2-devel expat-devel gdbm-devel readline-devel sqlite-devel libffi-devel
if [ ! -f './Python-3.7.3.tgz' ];then
    echo "本地没有Python源码包,需要远程下载,请耐心等待\n"
    wget https://www.python.org/ftp/python/3.7.3/Python-3.7.3.tgz
fi
tar xvf Python-3.7.3.tgz
cd Python-3.7.3
./configure --prefix=/usr/local/python3 --with-ssl && make && make install
echo 'PATH=/usr/local/python3/bin:$PATH' >> /etc/profile
source /etc/profile
===========================================================================================
#执行完成之后查看命令行
[root@localhost ~]# python3 --version
Python 3.7.3
[root@localhost ~]# pip3 --version
pip 19.0.3 from /usr/local/python3/lib/python3.7/site-packages/pip (python 3.7)
===========================================================================================
#配置pip国内源
shell > cd ~
shell > mkdir .pip
shell > cd .pip/
shell > vim pip.conf
#文件内容
[global]
index-url = http://pypi.douban.com/simple/
[install]
trusted-host = pypi.douban.com

4、数据收集API和客户端编写

①使用客户端收集到主机信息

 vim scan_file.py
 # coding:utf-8
import psutil

import platform
import os
import json
import requests
import distro


class GetData(object):
    def __init__(self):
        self.ret = {}

    def get_hostname(self):
        return platform.node()

    def get_cpu_info(self):
        ret = ''
        with open('/proc/cpuinfo') as f:
            for line in f:
                line_list = line.strip().split(':')
                key = line_list[0].strip()
                if key == 'models name':
                    ret = line_list[1]
        return ret.strip()

    def get_cpu_count(self):
        return psutil.cpu_count(logical=False)

    def get_mem_info(self):
        return '%.2f' % (psutil.virtual_memory().total / 1024 / 1024)

    def get_disk_info(self):
        disk_name_list = []
        disk_size_list = []
        disk_name_file = os.popen("lsblk | grep disk | awk '{print $1}'")
        disk_size_file = os.popen("lsblk | grep disk | awk '{print $4}'")
        for disk_name in disk_name_file.readlines():
            disk_name_list.append(disk_name.split()[0])
            for disk_size in disk_size_file.readlines():
                disk_size_list.append(disk_size.split()[0])
        return dict(zip(disk_name_list, disk_size_list))

    def get_ip_info(self):
        ret = {}
        for net_name in psutil.net_if_addrs():
            ret[net_name] = psutil.net_if_addrs()[net_name][0].address
        return ret

    def get_os_system(self):
        return distro.linux_distribution()[0] + ' ' + distro.linux_distribution()[1]
            def get_os_system_num(self):
        return platform.architecture()[0].strip('bit')

    def get_uuid(self):
        uuid = os.popen('dmidecode -s system-uuid')
        return uuid.read().strip()

    def get_sn(self):
        sn_popen = os.popen("dmidecode -t 1| grep 'Serial Number:'")
        sn = sn_popen.read()
        return sn.strip().strip('Serial Number:')

    def send_data(self):
        data_dict = GetData.__dict__
        for key, value in data_dict.items():
            if 'get_' in key:
                key = key.replace('get_', '')
                self.ret[key] = value(self)
        return self.ret


def send_data(url, data):
    response = requests.post(url, data)
    print(response.text)


if __name__ == '__main__':
    getdata = GetData().send_data()
    print(getdata)
#    send_data(url='http://10.1.1.1:8080/resources/server/api/', data=json.dumps(getdata))


在这里插入图片描述

②cmdb编写一个接收数据的API

路由

在这里插入图片描述

视图

在这里插入图片描述

③修改请求API的地址 scan_file.py

在这里插入图片描述

④查看可以获取到数据

在这里插入图片描述

5、添加资产主机

简单修改模型

在这里插入图片描述

视图

在这里插入图片描述

在收集主机上执行

在这里插入图片描述

显示效果

在这里插入图片描述

项目这里暂时开发到目前模块。

还可以做其他功能:参考一些开源的cmdb产品 jumpserver

①主动发送检测脚本到被监控机 python sftp传输

②管理主机使用webssh 可以实现一些开源的工具 webssh(后端建立长连接) xtemjs(前端显示命令行)

③web端的ftp

④接入监控的API 获取数据 通过highchart echart 出监控图表

⑤CI CD

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爪蛙毁一生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值