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   启动我们的网站

打开浏览器输入http://192.168.1.1:8080/admin/ 访问我们新创建的后台

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

101608_ftuX_1790313.jpg

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

101837_Rj58_1790313.jpg


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


101938_dR58_1790313.jpg

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

怎么样 很简单吧。

转载于:https://my.oschina.net/jastme/blog/341764

# 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、付费专栏及课程。

余额充值