CMDB项目之数据库表结构

asset 资产

server 服务器  network  网络设备

from django.db import models

class UserProfile(models.Model):
    """
    用户信息
    """
    name = models.CharField(u‘姓名‘, max_length=32)
    email = models.EmailField(u‘邮箱‘)
    phone = models.CharField(u‘座机‘, max_length=32)
    mobile = models.CharField(u‘手机‘, max_length=32)

    class Meta:
        verbose_name_plural = "用户表"

    def __str__(self):
        return self.name

class AdminInfo(models.Model):
    """
    用户登陆相关信息
    """
    user_info = models.OneToOneField("UserProfile")

    username = models.CharField(u‘用户名‘, max_length=64)
    password = models.CharField(u‘密码‘, max_length=64)

    class Meta:
        verbose_name_plural = "管理员表"

    def __str__(self):
        return self.user_info.name

class UserGroup(models.Model):
    """
    用户组
    """
    name = models.CharField(max_length=32, unique=True)
    users = models.ManyToManyField(‘UserProfile‘)

    class Meta:
        verbose_name_plural = "用户组表"

    def __str__(self):
        return self.name

class BusinessUnit(models.Model):
    """
    业务线
    """
    name = models.CharField(‘业务线‘, max_length=64, unique=True)
    contact = models.ForeignKey(‘UserGroup‘, verbose_name=‘业务联系人‘, related_name=‘c‘) # 多个人
    manager = models.ForeignKey(‘UserGroup‘, verbose_name=‘系统管理员‘, related_name=‘m‘) # 多个人

    class Meta:
        verbose_name_plural = "业务线表"

    def __str__(self):
        return self.name

class IDC(models.Model):
    """
    机房信息
    """
    name = models.CharField(‘机房‘, max_length=32)
    floor = models.IntegerField(‘楼层‘, default=1)

    class Meta:
        verbose_name_plural = "机房表"

    def __str__(self):
        return self.name

class Tag(models.Model):
    """
    资产标签
    """
    name = models.CharField(‘标签‘, max_length=32, unique=True)

    class Meta:
        verbose_name_plural = "标签表"

    def __str__(self):
        return self.name

class Asset(models.Model):
    """
    资产信息表,所有资产公共信息(交换机,服务器,防火墙等)
    """
    device_type_choices = (
        (1, ‘服务器‘),
        (2, ‘交换机‘),
        (3, ‘防火墙‘),
    )
    device_status_choices = (
        (1, ‘上架‘),
        (2, ‘在线‘),
        (3, ‘离线‘),
        (4, ‘下架‘),
    )

    device_type_id = models.IntegerField(choices=device_type_choices, default=1)
    device_status_id = models.IntegerField(choices=device_status_choices, default=1)

    cabinet_num = models.CharField(‘机柜号‘, max_length=30, null=True, blank=True)
    cabinet_order = models.CharField(‘机柜中序号‘, max_length=30, null=True, blank=True)

    idc = models.ForeignKey(‘IDC‘, verbose_name=‘IDC机房‘, null=True, blank=True)
    business_unit = models.ForeignKey(‘BusinessUnit‘, verbose_name=‘属于的业务线‘, null=True, blank=True)

    tag = models.ManyToManyField(‘Tag‘)

    latest_date = models.DateField(null=True)
    create_at = models.DateTimeField(auto_now_add=True)

    class Meta:
        verbose_name_plural = "资产表"

    def __str__(self):
        return "%s-%s-%s" % (self.idc.name, self.cabinet_num, self.cabinet_order)

class Server(models.Model):
    """
    服务器信息
    """
    asset = models.OneToOneField(‘Asset‘)

    hostname = models.CharField(max_length=128, unique=True)
    sn = models.CharField(‘SN号‘, max_length=64, db_index=True)
    manufacturer = models.CharField(verbose_name=‘制造商‘, max_length=64, null=True, blank=True)
    model = models.CharField(‘型号‘, max_length=64, null=True, blank=True)

    manage_ip = models.GenericIPAddressField(‘管理IP‘, null=True, blank=True)

    os_platform = models.CharField(‘系统‘, max_length=16, null=True, blank=True)
    os_version = models.CharField(‘系统版本‘, max_length=16, null=True, blank=True)

    cpu_count = models.IntegerField(‘CPU个数‘, null=True, blank=True)
    cpu_physical_count = models.IntegerField(‘CPU物理个数‘, null=True, blank=True)
    cpu_model = models.CharField(‘CPU型号‘, max_length=128, null=True, blank=True)

    create_at = models.DateTimeField(auto_now_add=True, blank=True)

    class Meta:
        verbose_name_plural = "服务器表"

    def __str__(self):
        return self.hostname

class NetworkDevice(models.Model):
    asset = models.OneToOneField(‘Asset‘)
    management_ip = models.CharField(‘管理IP‘, max_length=64, blank=True, null=True)
    vlan_ip = models.CharField(‘VlanIP‘, max_length=64, blank=True, null=True)
    intranet_ip = models.CharField(‘内网IP‘, max_length=128, blank=True, null=True)
    sn = models.CharField(‘SN号‘, max_length=64, unique=True)
    manufacture = models.CharField(verbose_name=u‘制造商‘, max_length=128, null=True, blank=True)
    model = models.CharField(‘型号‘, max_length=128, null=True, blank=True)
    port_num = models.SmallIntegerField(‘端口个数‘, null=True, blank=True)
    device_detail = models.CharField(‘设置详细配置‘, max_length=255, null=True, blank=True)

    class Meta:
        verbose_name_plural = "网络设备"

class Disk(models.Model):
    """
    硬盘信息
    """
    slot = models.CharField(‘插槽位‘, max_length=8)
    model = models.CharField(‘磁盘型号‘, max_length=32)
    capacity = models.FloatField(‘磁盘容量GB‘)
    pd_type = models.CharField(‘磁盘类型‘, max_length=32)
    server_obj = models.ForeignKey(‘Server‘,related_name=‘disk‘)

    class Meta:
        verbose_name_plural = "硬盘表"

    def __str__(self):
        return self.slot

class NIC(models.Model):
    """
    网卡信息
    """
    name = models.CharField(‘网卡名称‘, max_length=128)
    hwaddr = models.CharField(‘网卡mac地址‘, max_length=64)
    netmask = models.CharField(max_length=64)
    ipaddrs = models.CharField(‘ip地址‘, max_length=256)
    up = models.BooleanField(default=False)
    server_obj = models.ForeignKey(‘Server‘,related_name=‘nic‘)

    class Meta:
        verbose_name_plural = "网卡表"

    def __str__(self):
        return self.name

class Memory(models.Model):
    """
    内存信息
    """
    slot = models.CharField(‘插槽位‘, max_length=32)
    manufacturer = models.CharField(‘制造商‘, max_length=32, null=True, blank=True)
    model = models.CharField(‘型号‘, max_length=64)
    capacity = models.FloatField(‘容量‘, null=True, blank=True)
    sn = models.CharField(‘内存SN号‘, max_length=64, null=True, blank=True)
    speed = models.CharField(‘速度‘, max_length=16, null=True, blank=True)

    server_obj = models.ForeignKey(‘Server‘,related_name=‘memory‘)

    class Meta:
        verbose_name_plural = "内存表"

    def __str__(self):
        return self.slot

class AssetRecord(models.Model):
    """
    资产变更记录,creator为空时,表示是资产汇报的数据。
    """
    asset_obj = models.ForeignKey(‘Asset‘, related_name=‘ar‘)
    content = models.TextField(null=True)
    creator = models.ForeignKey(‘UserProfile‘, null=True, blank=True)
    create_at = models.DateTimeField(auto_now_add=True)

    class Meta:
        verbose_name_plural = "资产记录表"

    def __str__(self):
        return "%s-%s-%s" % (self.asset_obj.idc.name, self.asset_obj.cabinet_num, self.asset_obj.cabinet_order)

class ErrorLog(models.Model):
    """
    错误日志,如:agent采集数据错误 或 运行错误
    """
    asset_obj = models.ForeignKey(‘Asset‘, null=True, blank=True)
    title = models.CharField(max_length=16)
    content = models.TextField()
    create_at = models.DateTimeField(auto_now_add=True)

    class Meta:
        verbose_name_plural = "错误日志表"

    def __str__(self):
        return self.title

原文地址:https://www.cnblogs.com/jintian/p/11297305.html

时间: 2024-08-05 15:55:05

CMDB项目之数据库表结构的相关文章

activiti数据库表结构全貌解析

下面本人介绍一些activiti这款开源流程设计引擎的数据库表结构,首先阐述:我们刚开始接触或者使用一个新的东西(技术)时我们首先多问一下自己几个为什么?为什么activiti在工作流程领域这么流行呢?仅仅是因为开源么?实现如此强大的流程引擎,activiti底层设计是如何进行的?activiti中依赖哪些技术等?这些可能应该是那些刚接触这个开源流程引擎产品的人应该有的疑问.我们在用开源产品的都是其实应该多问自己为什么?这样才能有所进步,不是么?兴许你一时兴起,“起笔”就把一款属于你自己的开源作

FocusBI: 《DW/BI项目管理》之数据库表结构 (原创)

关注微信公众号:FocusBI 查看更多文章:加QQ群:808774277 获取学习资料和一起探讨问题. <商业智能教程>pdf下载地址 链接:https://pan.baidu.com/s/1f9VdZUXztwylkOdFLbcmWw 密码:2r4v 数据行业发展的很快,很多一起做BI的朋友都已转入大数据.云计算.人工智能等高大上的领域去了,而我还停留在原地做BI,导致能一起讨论问题的人越来越少,我还有太多BI领域的知识不会,需要深入学习,只好一个人慢慢前行一点一点的去学. 在做BI实施的

EntityFrameworkCore教程:Web项目生成数据库表

一.引言 这篇文章中我们讲解如何在Web项目中使用EntityFrameworkCore,并生成数据库表,这里以ASP.NET Core WebApi为例讲解.还是采用分层的结构.创建后的项目整体结构如下图所示: 项目结构: EFCoreWeb.API:ASP.NET Core WebApi项目,用来提供Web功能,在项目中会引用EFCoreWeb.Data. EFCoreWeb.Data:类库项目,基于.NET Core的类库.存放的是与EFCore相关的操作. EFCoreWeb.Model

请设计一套图书馆借书管理系统的数据库表结构

请设计一套图书馆借书管理系统的数据库表结构:可以记录基本的用户信息.图书信息.借还书信息:数据表的个数不超过6个:请画表格描述表结构(需要说明每个字段的字段名.字段类型.字段含义描述): 在数据库设计中应: 1.保证每个用户的唯一性: 2.保证每种图书的唯一性:每种图书对应不等本数的多本图书:保证每本图书的唯一性: 3.借书信息表中,应同时考虑借书行为与还书行为,考虑借书期限: 4.保证借书信息表与用户表.图书信息表之间的参照完整性: 5.限制每个用户最大可借书的本数 6.若有新用户注册或新书入

关系型数据库表结构设计规范-浅谈(转)

数据库表结构设计规范-浅谈,为啥是浅谈呢,因为主要的观点还是来自原微信公共账号的一篇文章,稍微加了一些自己的看法. 谁来进行数据库的设计? 肯定是具体的开发工程师来进行,开发同学的话,第一业务熟悉度比较高,第二结合OO和ORM的思想,能有比较好的运用关系型数据库的特性.如果是DBA同学的话,虽然对于数据库本身了解比较多,但是对于业务了解较少,很难有比较客观的设计.但是业务上线或者运行期间,需要DBA同学能够重度的加入进来,针对一些性能点和不合理的点进行优化,同事也可以在上线前,针对SQL进行re

OSSIM主要数据库表结构

OSSIM主要数据库表结构 对于从事OSSIM开发的技术人员,最主要的需要知道OSSIM库里的多种表结构,下面举几个典型事例: /* ======== config表 ======== */ DROP TABLE IF EXISTS conf; CREATE TABLE conf ( recovery        int NOT NULL, threshold       int NOT NULL, graph_threshold int NOT NULL, bar_length_left i

Activiti数据库表结构(表详细版)

http://blog.csdn.net/hj7jay/article/details/51302829 1  Activiti数据库表结构 1.1      数据库表名说明 Activiti工作流总共包含23张数据表,所有的表名默认以“ACT_”开头. 并且表名的第二部分用两个字母表明表的用例,而这个用例也基本上跟Service API匹配. u  ACT_GE_* : “GE”代表“General”(通用),用在各种情况下: u  ACT_HI_* : “HI”代表“History”(历史)

开源一个适用iOS的数据库表结构更新机制的代码

将前段时间开源的代码,发布一下: ARDBConfig On the iOS, provide a database table structure update mechanism, ensure that the user in any version of the installer, the database structure to ensure adapter. (在iOS上,提供一个数据库表结构更新的机制,保证用户无论从哪个版本安装程序,数据库结构保证适配.) 如:用户A的数据库版

ECshop 数据库表结构

ECshop 数据库表结构 -- 表的结构 `ecs_account_log`CREATE TABLE IF NOT EXISTS `ecs_account_log` (`log_id` mediumint(8) unsigned NOT NULL AUTO_INCREMENT COMMENT '自增ID号',`user_id` mediumint(8) unsigned NOT NULL COMMENT '用户登录后保存在session中的id号,跟users表中的user_id对应',`us