python资产管理系统_Django-admin-01 运维管理后台搭建--资产管理系统

如何搭建一个运维后台,能让我们完成自动化管理。

我们的第一步如何做好一个简洁的资产管理系统。

我在这里就使用Django-admin来搭建这个系统。

首先创建一个项目,在我使用的1.7版本的Django

root@CD-FTP-VPN:/opt# django-admin startproject Ops_System   项目名字为Ops_System

root@CD-FTP-VPN:/opt# cd Ops_System

root@CD-FTP-VPN:/opt/Ops_System# tree                             #这里是目录树。

.

|-- manage.py

`-- Ops_System

|-- __init__.py

|-- settings.py

|-- urls.py

`-- wsgi.py

1 directory, 5 files

继续创建一个APP

root@CD-FTP-VPN:/opt/Ops_System# django-admin startapp Asset_management

root@CD-FTP-VPN:/opt/Ops_System# tree

.

|-- Asset_management

|   |-- admin.py

|   |-- __init__.py

|   |-- migrations

|   |   `-- __init__.py

|   |-- models.py

|   |-- tests.py

|   `-- views.py

|-- manage.py

`-- Ops_System

|-- __init__.py

|-- settings.py

|-- urls.py

`-- wsgi.py

这里要注意下settings.py是全局的配置,即项目下的所有全局配置都在这里,下面要说的urls.py也类似

配置项目下的setting文件

root@CD-FTP-VPN:/opt/Ops_System# vim Ops_System/settings.py

"""

Django settings for pay1pay project.

For more information on this file, see

https://docs.djangoproject.com/en/1.7/topics/settings/

For the full list of settings and their values, see

https://docs.djangoproject.com/en/1.7/ref/settings/

"""

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)

import os

BASE_DIR = os.path.dirname(os.path.dirname(__file__))                        #变量,路径是指的我们项目的初始路径/opt/Ops_System

# Quick-start development settings - unsuitable for production

# See https://docs.djangoproject.com/en/1.7/howto/deployment/checklist/

# SECURITY WARNING: keep the secret key used in production secret!

SECRET_KEY = '0f-rcb1@lb3%105!zcwt4dk*ykutswchc6if3p4rv&jt2-1^y4'

# SECURITY WARNING: don't run with debug turned on in production!

DEBUG = True                                                                 #我们开启debug方便排错,加上运维系统使用的人也不多,完全不需要第3方类似Apache的HTTP服务的支持。

TEMPLATE_DEBUG = True

ALLOWED_HOSTS = []

# Application definition

INSTALLED_APPS = (

'django.contrib.admin',

'django.contrib.auth',

'django.contrib.contenttypes',

'django.contrib.sessions',

'django.contrib.messages',

'django.contrib.staticfiles',

'Asset_management',                                                 #添加我们的项目

)

MIDDLEWARE_CLASSES = (

'django.contrib.sessions.middleware.SessionMiddleware',

'django.middleware.common.CommonMiddleware',

'django.middleware.csrf.CsrfViewMiddleware',

'django.contrib.auth.middleware.AuthenticationMiddleware',

'django.contrib.auth.middleware.SessionAuthenticationMiddleware',

'django.contrib.messages.middleware.MessageMiddleware',

'django.middleware.clickjacking.XFrameOptionsMiddleware',

'django.middleware.locale.LocaleMiddleware',                                #这个类让我们可以使得DJANGO的在前端展示的语言和系统同步。

)

ROOT_URLCONF = 'Ops_System.urls'

WSGI_APPLICATION = 'Ops_System.wsgi.application'

# Database

# https://docs.djangoproject.com/en/1.7/ref/settings/#databases

DATABASES = {                                                             #我在这里是使用mysql,Django默认的是sqlite3

'default': {

'ENGINE': 'django.db.backends.mysql',

#        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),

'NAME':'Ops_System',

'USER':'ops',

'PASSWORD':'ops',

'HOST':'localhost',

'PORT':'3306',

}

}

# Internationalization

# https://docs.djangoproject.com/en/1.7/topics/i18n/

LANGUAGE_CODE = 'en-us'

TIME_ZONE = 'Asia/Shanghai'                            #修改时区,不然Django的时间和我们系统时间会不一致

USE_I18N = True

USE_L10N = True

USE_TZ = True

# Static files (CSS, JavaScript, Images)

# https://docs.djangoproject.com/en/1.7/howto/static-files/

STATIC_URL = '/static/'

启用urls.py

root@CD-FTP-VPN:/opt/Ops_System# vim Ops_System/urls.py

from django.conf.urls import patterns, include, url

from django.contrib import admin

urlpatterns = patterns('',

# Examples:

# url(r'^$', 'Ops_System.views.home', name='home'),

# url(r'^blog/', include('blog.urls')),

url(r'^admin/', include(admin.site.urls)),                             # Django默认已经启用了admin

)

APP下的models.py

root@CD-FTP-VPN:/opt/Ops_System# vim Asset_management/models.py

# -*- coding:utf-8 -*-

from django.db import models

# Create your models here.

class ServerList(models.Model):

hostname=models.CharField(max_length=50,verbose_name=u'主机名')

base=models.CharField(max_length=100,verbose_name=u'机房')

location=models.CharField(max_length=50,verbose_name=u'机架')

version=models.CharField(max_length=50,verbose_name=u'型号')

memory=models.CharField(max_length=15,verbose_name=u'内存')

disk=models.CharField(max_length=50,verbose_name=u'硬盘')

cpu=models.CharField(max_length=50,verbose_name=u'CPU')

disk_array=models.CharField(max_length=50,verbose_name=u'硬盘阵列')

power=models.CharField(max_length=100,verbose_name=u'电源')

extend_hardware=models.CharField(max_length=50,blank=True, null=True,verbose_name=u'额外添加')

wan_ip=models.CharField(max_length=80,verbose_name=u'外网IP')

Intranet_ip=models.CharField(max_length=80,verbose_name=u'内网IP')

os=models.CharField(max_length=50,verbose_name=u'系统版本')

usage=models.CharField(max_length=80,verbose_name=u'用途')

serial_number=models.CharField(max_length=100,verbose_name=u'序列号')

fixed_assets_encoding=models.CharField(max_length=100,verbose_name=u'固定资产编号')

ops_history=models.TextField(verbose_name=u'操作历史',blank=True, null=True)

comment=models.TextField(verbose_name=u'注释',blank=True, null=True)

def __unicode__(self):

return u'%s %s %s %s %s %s %s %s %s %s %s %s %s %s %s %s %s %s' %(self.hostname,self.base,self.location,self.version,self.memory,self.disk,self.cpu,self.disk_array,self.power,self.extend_hardware,self.wan_ip,self.Intranet_ip,self.os,self.usage,self.serial_number,self.fixed_assets_encoding,self.ops_history,self.comment)

APP下的admin.py

root@CD-FTP-VPN:/opt/Ops_System# vim Asset_management/admin.py

from django.contrib import admin

# Register your models here.

from Asset_management.models import ServerList

class TitleList(admin.ModelAdmin):

list_display = ('hostname','base','location','version','memory','disk','cpu','disk_array','power','extend_hardware','wan_ip','Intranet_ip','os','usage','serial_number','fixed_assets_encoding','ops_history','comment')

search_fields = ('hostname','base','location','version','memory','disk','cpu','disk_array','power','extend_hardware','wan_ip','Intranet_ip','os','usage','serial_number','fixed_assets_encoding')

admin.site.register(ServerList,TitleList)

删除 migrations 目录

root@CD-FTP-VPN:/opt/Ops_System# rm Asset_management/migrations/ -rf

创建数据库,赋予权限

CREATE DATABASE `Ops_System` /*!40100 DEFAULT CHARACTER SET utf8 */;

GRANT ALL PRIVILEGES ON `Ops_System`.* TO 'ops'@'localhost' identified by 'ops';

同步数据库

root@CD-FTP-VPN:/opt/Ops_System# python manage.py syncdb

Operations to perform:

Synchronize unmigrated apps: Asset_management

Apply all migrations: admin, contenttypes, auth, sessions

Synchronizing apps without migrations:

Creating tables...

Creating table Asset_management_serverlist

Installing custom SQL...

Installing indexes...

Running migrations:

Applying contenttypes.0001_initial... OK

Applying auth.0001_initial... OK

Applying admin.0001_initial... OK

Applying sessions.0001_initial... OK

You have installed Django's auth system, and don't have any superusers defined.

Would you like to create one now? (yes/no): yes

Username (leave blank to use 'root'): admin                         创建用户admin

Email address:

Password:

Password (again):

Superuser created successfully.

root@CD-FTP-VPN:/opt/Ops_System#

现在开始启动啦

先写个启动脚本

root@CD-FTP-VPN:/opt/Ops_System# vim start.sh

#!/bin/sh

export.UTF-8

python manage.py runserver 0.0.0.0:8080

root@CD-FTP-VPN:/opt/Ops_System# sh start.sh   启动我们的网站

输入密码账号进入我们可以看见我们定义的ServerList

点击增加,我们试着加一条记录

点击保存,我们能返回这个列表

怎么样,这个UI不错的吧。到这里一个简单的资产管理后台就做好了。

怎么样 很简单吧。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
# CMDB and ansible ui ## 安装参考 - python2.7 - 使用sqlite需要初始化数据库 - 如使用mysql需要创建CMDB库,映射,修改setting数据库信息 - 安装步骤查看help/install - 初次使用需要注册用户(之后会加入用户权限控制) ## 资产管理 ### 1、添加主机 **单台主机添加,需要填写主机的全部信息,一次只能添加一台** ![](http://i.imgur.com/QoPa8ze.png) **批量添加主机,切记不用填写主机的全部信息,只需写ip 主机名即可,写多会报错(下个版本会增加判断用户的输入)** ![](http://i.imgur.com/dr4SPXC.png) ![](http://i.imgur.com/jtXDNbv.png) **提交后,会提示提交成功的有几个,如果重复多次提交,就会提示有几台服务器已存在** ### 2、主机列表 **资产管理==>>主机列表** ![](http://i.imgur.com/CB5JFWZ.png) 1. **更新:点击绿色更新按钮,然后鼠标放到主机名的位置,就会显示服务器的基本信息,第一次不点击更新不会显示,每次点击都会重新获取,如服务器可变化的参数:内存等等,如下图:** ![](http://i.imgur.com/jTpGORn.png) 2. **编辑:点击编辑按钮,可以修改服务器的信息,这里以数据库的ID为主键,所以IP也可以修改,可以理解为原来的删除又重新创建,但是主键ID不改变,如下图:** ![](http://i.imgur.com/FI3tSih.png) 3. **删除:点击删除按钮,此服务器就会被删除,需要注意的是,在密钥管理菜单中也有主机列表,那个主机列表的删除仅仅是删除服务器上的所有公钥,不会删除服务器,如下图:** ![](http://i.imgur.com/oKIRIlk.png) ## 密钥管理 ### 1、密钥用户 **以用户为入口,可以增加密钥用户,修改用户公钥,对某用户授权其可以登陆的服务器** **增加密钥用户:填写用户名,公钥(公钥格式要填写正确,否则无法推送)** ![](http://i.imgur.com/B7mA92i.png) ![](http://i.imgur.com/CalhJM3.png) 1. **编辑:点击编辑,弹出一个主机列表,可以对主机列表的服务器给此用户授权,主机列表的服务器就是资产管理中添加的主机,如下图:** ![](http://i.imgur.com/BGMqy1d.png) **添加成功后,鼠标点击可登陆的服务器数即能显示此用户可以登陆的服务器,如果不看,需要再点击一次,多台服务器的话都可以点出来,一起看,如下图:** ![](http://i.imgur.com/tctIbIG.png) 2. **删除:删除会删除此用户的所有的授权信息,并把此用户的可登陆的服务器的公钥都删除,但不会删除用户本身,之后的版本会加入离职人员,删除授权信息加用户本身,如下图:** ![](http://i.imgur.com/lzB8715.png) ![](http://i.imgur.com/04kfMAi.png) 3. **更新公钥:可以对此用户的公钥修改更新,如下图:** ![](http://i.imgur.com/mC0McnZ.png) ### 2、主机列表 **以主机为入口,可以对服务器进行用户授权,删除权限** ![](http://i.imgur.com/2vAdfgu.png) 1. **编辑:编辑显示用户列表,表示对此服务器可以允许哪些用户登录,如下图:** ![](http://i.imgur.com/5zbhdos.png) **授权成功后,点击允许登陆的用户,即可显示此服务器允 -------- 该资源内项目源码是个人的毕设,代码都测试ok,都是运行成功后才上传资源,答辩评审平均分达到96分,放心下载使用! <项目介绍> 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值