百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程字典 > 正文

基于Django的Admin后台实现定制简单监控页

toyiye 2024-09-16 06:10 4 浏览 0 评论

Django自带的后台管理是Django明显特色之一,可以让我们快速便捷管理数据。后台管理可以在各个app的admin.py文件中进行控制。本文将主要介绍如何利用Admin后台实现监控页的定制,快来和小编一起学习一下吧

我们使用Django的Admin二次定制一个图形化界面,首先我们把语言设置为中文简体.

修改: settings.py
LANGUAGE_CODE = 'zh-hans'
TIME_ZONE = 'Asia/Shanghai'
修改: apps.py
from django.apps import AppConfig
class MywebConfig(AppConfig):
name = 'MyWeb'
verbose_name = "服务器参数收集"


接着我们来定义models.py数据库模型,定义基本的数据查询.

from django.db import models
from django.utils.html import format_html
import datetime
STATUS_CHOICES = (('d', '在用设备'), ('p', '下线设备'), ('w', '损坏设备'),)
# 定义主机基本信息表
class HostInfoDB(models.Model):
id = models.AutoField(primary_key=True)
# HostAddr = models.TextField(max_length=128,verbose_name="主机地址")
HostAddr = models.CharField(max_length=128, verbose_name="主机地址")
HostName = models.CharField(max_length=128, verbose_name="主机名称")
HostType = models.CharField(max_length=128, verbose_name="系统类型")
HostPosition = models.CharField(max_length=128, verbose_name="机房位置")
HostPlatform = models.CharField(max_length=128, verbose_name="所属平台")
HostGroup = models.CharField(max_length=128, verbose_name="分组")
HostDataTime = models.DateTimeField(verbose_name="检查日期")
HostUser = models.CharField(max_length=64, verbose_name="负责人")
hostStats = models.CharField(max_length=1, choices=STATUS_CHOICES, verbose_name="设备状态")
def __str__(self):
return self.HostName
# 用于给本表指定别名,这样前端就不是英文的了
class Meta():
verbose_name = "设备清单"
verbose_name_plural = "设备清单"
# 设备再用状态
def Status(self):
if self.hostStats == 'd':
format_td = format_html('<span style="padding:2px;background-color:green;color:white">在用设备</span>')
elif self.hostStats == 'p':
format_td = format_html('<span style="padding:2px;background-color:yellow;color:black">下线设备</span>')
elif self.hostStats == 'w':
format_td = format_html('<span style="padding:2px;background-color:red;color:white">损坏设备</span>')
return format_td
Status.short_description = "当前状态"
# 指定Ping检测结果表
class HostPingInfo(models.Model):
id = models.AutoField(primary_key=True)
HostAddr = models.CharField(max_length=128, verbose_name="主机地址")
flage = models.CharField(max_length=64)
class Meta():
verbose_name = "存活检测"
verbose_name_plural = "存活检测"
def Status(self):
if self.flage == "True":
ret = "已连接"
color = "green"
return format_html('<span style="color:{};">{}</span>',color,ret,)
elif self.flage == "False":
ret = "未连接"
color = "red"
return format_html('<span style="color:{};">{}</span>', color, ret,)
Status.short_description = "状态"
# 定义CPU/内存利用率数据表结构
class HostCPUOrMemInfo(models.Model):
id = models.AutoField(primary_key=True)
HostAddr = models.CharField(max_length=128, verbose_name="主机地址")
Cpu_Count = models.IntegerField()
Mem_Count = models.IntegerField()
class Meta():
verbose_name = "CPU内存性能"
verbose_name_plural = "CPU内存性能"
def Cpu_Speed(self):
return format_html('<progress max="100" value="{}"></progress>',self.Cpu_Count)
def Mem_Speed(self):
return format_html('<progress max="100" value="{}"></progress>',self.Mem_Count)
def Check(self):
return format_html('<a href="/admin/MyWeb/hostdb/{}/change/" rel="external nofollow" >查看</a>',self.id)
Cpu_Speed.short_description = "CPU利用率"
Mem_Speed.short_description = "Mem利用率"

继续定制admin.py并与上方的数据库视图相交互.

from django.contrib import admin
from MyWeb.models import *
# 必须继承ModelAdmin基类,才可以调整参数,HostDB则是你的表的名称
@admin.register(HostInfoDB)
class MyAdmin(admin.ModelAdmin):
admin.site.site_title="后台管理"
admin.site.site_header = "自动化监控平台"
# list_display = 你需要展示的字段应该写在这里,此处是数据库中的字段
list_display = ("HostAddr","HostName","HostType","HostPosition","HostDataTime","HostPlatform","HostGroup","HostUser","Status")
# search_fields = 用于添加一个搜索框,此处作为查询条件
#search_fields = ("HostAddr","HostType","Status",)
# list_filter = 设置一个过滤器,此处是过滤条件
list_filter = ("HostAddr","HostGroup",)
# ordering = 设置一个排序条件,此处是以id作为排序依据
ordering = ("id",)
#list_per_page = 设置每页显示多少条记录,默认是100条
list_per_page = 10
#list_editable = 设置默认可编辑字段
#list_editable = ("HostName",)
# date_hierarchy = 显示详细时间分层筛选
date_hierarchy = 'HostDataTime'
# readonly_fields = 可以设置只读字段,就是无法修改的字段
#readonly_fields = ("hostCPU","hostMEM",)
# 定义Ping检测显示字段
@admin.register(HostPingInfo)
class MyAdmin(admin.ModelAdmin):
list_display = ("HostAddr","flage","Status")
# 定义内存CPU利用率字段
@admin.register(HostCPUOrMemInfo)
class MyAdmin(admin.ModelAdmin):
list_display = ("id","HostAddr","Cpu_Count","Cpu_Speed","Mem_Count","Mem_Speed","Check")


保存后直接执行命令,完成命令行建表操作.

python manage.py makemigrations
python manage.py migrate
python manage.py createsuperuser

保存后启动,Django并访问http://127.0.0.1:8000/admin登录后我们依次看一下定制效果.

主页中的展示效果如下.

当我们需要增加自定义动作时,可以这样写,我们以HostCPUOrMemInfo为例


# 定义内存CPU利用率字段
@admin.register(HostCPUOrMemInfo)
class MyAdmin(admin.ModelAdmin):
list_display = ("id","HostAddr","Cpu_Count","Cpu_Speed","Mem_Count","Mem_Speed")
# 添加的自定义动作,此处可执行操作
def func(self, request, queryset):
# 此处可以写一些执行动作
print(self, request, queryset)
func.short_description = "自定义active动作"
actions = [func, ]
# Action选项都是在页面上方显示
actions_on_top = True
# Action选项都是在页面下方显示
actions_on_bottom = False
# 是否显示选择个数
actions_selection_counter = True


以上就是基于Django的Admin后台实现定制简单监控页的详细内容

原文:https://www.jb51.net/article/231017.htm

相关推荐

为何越来越多的编程语言使用JSON(为什么编程)

JSON是JavascriptObjectNotation的缩写,意思是Javascript对象表示法,是一种易于人类阅读和对编程友好的文本数据传递方法,是JavaScript语言规范定义的一个子...

何时在数据库中使用 JSON(数据库用json格式存储)

在本文中,您将了解何时应考虑将JSON数据类型添加到表中以及何时应避免使用它们。每天?分享?最新?软件?开发?,Devops,敏捷?,测试?以及?项目?管理?最新?,最热门?的?文章?,每天?花?...

MySQL 从零开始:05 数据类型(mysql数据类型有哪些,并举例)

前面的讲解中已经接触到了表的创建,表的创建是对字段的声明,比如:上述语句声明了字段的名称、类型、所占空间、默认值和是否可以为空等信息。其中的int、varchar、char和decimal都...

JSON对象花样进阶(json格式对象)

一、引言在现代Web开发中,JSON(JavaScriptObjectNotation)已经成为数据交换的标准格式。无论是从前端向后端发送数据,还是从后端接收数据,JSON都是不可或缺的一部分。...

深入理解 JSON 和 Form-data(json和formdata提交区别)

在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:...

JSON 语法(json 语法 priority)

JSON语法是JavaScript语法的子集。JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔花括号保存对象方括号保存数组JS...

JSON语法详解(json的语法规则)

JSON语法规则JSON语法是JavaScript对象表示法语法的子集。数据在名称/值对中数据由逗号分隔大括号保存对象中括号保存数组注意:json的key是字符串,且必须是双引号,不能是单引号...

MySQL JSON数据类型操作(mysql的json)

概述mysql自5.7.8版本开始,就支持了json结构的数据存储和查询,这表明了mysql也在不断的学习和增加nosql数据库的有点。但mysql毕竟是关系型数据库,在处理json这种非结构化的数据...

JSON的数据模式(json数据格式示例)

像XML模式一样,JSON数据格式也有Schema,这是一个基于JSON格式的规范。JSON模式也以JSON格式编写。它用于验证JSON数据。JSON模式示例以下代码显示了基本的JSON模式。{"...

前端学习——JSON格式详解(后端json格式)

JSON(JavaScriptObjectNotation)是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScriptProgrammingLa...

什么是 JSON:详解 JSON 及其优势(什么叫json)

现在程序员还有谁不知道JSON吗?无论对于前端还是后端,JSON都是一种常见的数据格式。那么JSON到底是什么呢?JSON的定义...

PostgreSQL JSON 类型:处理结构化数据

PostgreSQL提供JSON类型,以存储结构化数据。JSON是一种开放的数据格式,可用于存储各种类型的值。什么是JSON类型?JSON类型表示JSON(JavaScriptO...

JavaScript:JSON、三种包装类(javascript 包)

JOSN:我们希望可以将一个对象在不同的语言中进行传递,以达到通信的目的,最佳方式就是将一个对象转换为字符串的形式JSON(JavaScriptObjectNotation)-JS的对象表示法...

Python数据分析 只要1分钟 教你玩转JSON 全程干货

Json简介:Json,全名JavaScriptObjectNotation,JSON(JavaScriptObjectNotation(记号、标记))是一种轻量级的数据交换格式。它基于J...

比较一下JSON与XML两种数据格式?(json和xml哪个好)

JSON(JavaScriptObjectNotation)和XML(eXtensibleMarkupLanguage)是在日常开发中比较常用的两种数据格式,它们主要的作用就是用来进行数据的传...

取消回复欢迎 发表评论:

请填写验证码