目录

  1. 项目介绍和源码
  2. 拿来即用的bootstrap模板
  3. 服务器SSH服务配置与python中paramiko的使用
  4. 用户登陆与session;
  5. 最简单的实践之修改服务器时间
  6. 查看和修改服务器配置与数据库的路由
  7. 基于websocket的实时日志实现
  8. 查看服务器中的日志与前端的datatable的利用
  9. 重启服务器的进程。

前言

  相当于前面的文章而言,这篇文章就比较简短了。关于服务器中进程需要经常批量的重启,一般会在服务器中写个shell脚本去统一执行,网页的功能仅仅是用paramiko函数调用服务器中的shell脚本就好,然后把失败和成功的重启记录在前端记录下来。页面如图1所示。

功能实现

页面显示

  • 页面html函数

  页面仅仅由一个执行重启操作的模块和记录重启次数的模块构成。当然A在重启时,B进入网站是不能执行重启的,html代码中的{{taskor}}变量中记录的就是后台重启时当下操作人,具体的实现在操作互斥中会说说。

{% extends "./base.html" %}

{% block css %}{% endblock %}
{% block title %}{{ title }}{% endblock %}
{% block log %}{{ title }}{% endblock %}
{% block username %}{{ username }}{% endblock %} {% block mainbody %}
<section class="wrapper site-min-height">
<div class="fakeloader"></div>
<h3><i class="fa fa-angle-right"></i> 服务器重启 <i class="fa fa-refresh"></i></h3>
<div class="row mt">
<div class="col-lg-12">
<div class="form-panel">
<h4 class="mb"> 服务器重启</h4>
{% if taskor != '' %}
<div class="col-sm-12">
<div class="alert alert-danger" id="loading-tips"><b>稍等~</b> 【{{taskor}}】正在重启进程...</div>
</div>
<div><br><br><br><br></div>
{% else %}
<div class="col-sm-12">
<div class="alert alert-danger" id="pre-tips"><b>注意!</b> 此操作将会导致进程重启。</div>
<div class="alert alert-danger" style="display:none;" id="loading-tips"><b>稍等~</b> 进程正在重启...</div>
<div class="progress progress-striped active" style="display:none;" id="loading">
<div class="progress-bar" role="progressbar" aria-valuenow="100" aria-valuemin="0" aria-valuemax="100" style="width: 100%"></div>
</div>
</div>
<div><br><br><br><br></div>
<div class="col-sm-12" style="text-align: right">
<button type="button" id="restart" class="btn btn-theme04">重启服务器</button>
</div>
<div><br><br><br></div>
{% endif %}
</div>
</div>
</div>
<div class="row mt">
<div class="col-lg-12">
<div class="form-panel">
<h4 class="mb"> 重启服务器的记录</h4>
<table class="table table-hover">
<thead>
<tr>
<th style="width:10%;">重启时间</th>
<th style="width:10%;">重启人</th>
<th style="width:10%;">重启是否成功</th>
</tr>
</thead>
<tbody id="tab">
{% for item in reboot %}
<tr>
<td>{{ item.reboottime }}</td>
<td>{{ item.rebooter }}</td>
<td>{{ item.rebootresult }}</td>
</tr>
{% endfor %}
</tbody>
</table>
</div>
</div>
</div>
</section>
{% endblock %}
  • 页面javascript函数

  页面用到的javascript函数也仅仅是对图1中唯一一个按钮批量重启进程作用(函数中的swal只是一个模态框插件,每当点击按钮时唤起,如图2,关于它的引用文章用户登陆与session提到过),函数通过ajax请求到后端处理。

{% block scripts %}
<script>
$(document).ready(function(){
$("#restart").click(function(){
swal({
title: '您确定要重启吗?',
type: 'warning',
confirmButtonColor: '#DD6B55',
confirmButtonText:"是的,我要重启!",
cancelButtonText:"让我再考虑一下…",
showLoaderOnConfirm: true, //加载按钮是否可见
showCancelButton: true,
preConfirm: function() {
return new Promise(function(resolve) {
setTimeout(function(){
$("#restart").hide();
$("#pre-tips").hide();
$("#loading-tips").show();
$("#loading").show();
resolve();
}, 3000);
});
},
allowOutsideClick: false, //弹框外是否可点
}).then(function(res){
if (res){
$.ajax({
url:"restartserver",
type:'GET',
success: function(arg){
ret = eval(arg);
if(ret.status){
swal({
type: 'success',
title: '重启完成!',
confirmButtonText: '确定',
confirmButtonColor: '#4cd964'
}).then(function(){
window.location.reload();
});
}else{
swal({
type: 'error',
title: '重启失败!',
confirmButtonText: '确定',
confirmButtonColor: '#4cd964'
}).then(function(){
window.location.reload();
});
}
}});
}})
});
});
</script>
{% endblock %}
  • 创建model函数

  这里会创建两个model函数,一个在最简单的实践之修改服务器时间中提到过的taskinbackground,它可以将正在进行的事件记录在数据库中,另外一个是记录重启操作的表rebootserver。

# -*- coding: utf-8 -*-
from __future__ import unicode_literals
from django.db import models class taskinbackground(models.Model):
taskname = models.CharField(max_length=50)
taskor = models.CharField(max_length=100) class Meta:
db_table = 'task'
app_label = "server" class rebootserver(models.Model):
rebooter = models.CharField(max_length=100)
reboottime = models.CharField(max_length=200, default="")
rebootresult = models.CharField(max_length=200, default="") class Meta:
db_table = 'reboot'
app_label = "server"
  • 增加url和view函数

  server/urls.py中添加reboot和restartserver,前者用来渲染页面的,后者是用来实现重启的功能。

from django.conf.urls import url
import views urlpatterns = [
url(r'^reboot', views.rebootserver),
url(r'^restartserver', views.restartserver),
]

  server/views.py中添加渲染页面的函数rebootserver,和重启的功能函数restartserver。

# -*- coding: utf-8 -*-
from __future__ import unicode_literals from django.contrib.auth import logout
from django.shortcuts import render_to_response
from django.http import JsonResponse
from django.contrib.auth.decorators import login_required
import json
import time # 服务器的名字
htmltitle = '服务器工具' # 渲染页面
@login_required(login_url='/loginpage')
def rebootserver(request):
from server import models
username = request.session.get('username')
# 取出数据库后10条重启的数据
reboot = models.rebootserver.objects.all()[::-1][0:10]
taskor = ''
try:
# 后台是否有其他人在重启
taskor = models.taskinbackground.objects.get(taskname='reboot').taskor
except Exception as e:
print e
pagedict = {'reboot': reboot, 'title': htmltitle, 'taskor': taskor, 'username': username}
return render_to_response("servermaterial/reboot.html", pagedict) # 重启进程
def restartserver(request):
if request.method == 'GET':
ret = {'status': False}
from WebTool.functions import rebootserver
from server import models
username = request.session.get('username')
models.taskinbackground.objects.filter(taskname='reboot').delete()
# 将重启进程的任务写进数据库
models.taskinbackground.objects.create(taskname='reboot', taskor=username)
res = rebootserver()
local_time = time.strftime("%Y-%m-%d %H:%M:%S", time.localtime())
if res == 'Successful Rebooted!':
ret['status'] = True
# 重启成功记录写入rebootserver中
models.rebootserver.objects.create(rebooter=username, reboottime=local_time, rebootresult='重启成功')
# 从taskinbackground中删除后台正在执行的重启任务
models.taskinbackground.objects.filter(taskname='reboot').delete()
return JsonResponse(ret)
elif res == 'Unsuccessful Rebooted!':
# 重启失败记录写入rebootserver中
models.rebootserver.objects.create(rebooter=username, reboottime=local_time, rebootresult='重启失败')
# 从taskinbackground中删除后台正在执行的重启任务
models.taskinbackground.objects.filter(taskname='reboot').delete()
ret['status'] = False
return JsonResponse(ret)
else:
models.rebootserver.objects.create(rebooter=username, reboottime=local_time, rebootresult='重启失败')
models.taskinbackground.objects.filter(taskname='reboot').delete()
ret['status'] = False
return JsonResponse(ret)

  看到这里,我们的重启进程的paramiko函数rebootserver写在functions(WebTool/WebTool/functions.py)中,由于自己的Linux没有环境,当时只好写了一个shell脚本模拟进程重启。具体内容请移步至文章服务器SSH服务配置与python中paramiko的使用

操作互斥

  文章最简单的实践之修改服务器时间提到过,当A修改时间时,其他人没法修改时间,这里用的方法也是同理,将重启进程看成一个后台任务,任务执行时写在model中的taskinbackground中,其他人打开页面时,页面渲染函数会在数据库中查一查有没有对应名字的任务taskor = models.taskinbackground.objects.get(taskname='reboot').taskor
如果有就不提供重启的功能,其效果如图3所示。

{% if taskor != '' %}
<div class="col-sm-12">
<div class="alert alert-danger" id="loading-tips"><b>稍等~</b> 【{{taskor}}】正在重启进程...</div>
</div>
<div><br><br><br><br></div>
{% else %}
<div class="col-sm-12">
<div class="alert alert-danger" id="pre-tips"><b>注意!</b> 此操作将会导致进程重启。</div>
<div class="alert alert-danger" style="display:none;" id="loading-tips"><b>稍等~</b> 进程正在重启...</div>
<div class="progress progress-striped active" style="display:none;" id="loading">
<div class="progress-bar" role="progressbar" aria-valuenow="100" aria-valuemin="0" aria-valuemax="100" style="width: 100%"></div>
</div>
</div>
<div><br><br><br><br></div>
<div class="col-sm-12" style="text-align: right">
<button type="button" id="restart" class="btn btn-theme04">重启服务器</button>
</div>
<div><br><br><br></div>
{% endif %}

  这个互斥的逻辑可以用下面的逻辑图图4描述。通俗点说,其实就相当于用数据库做了一个互斥量,一次只准一个线程执行任务

结语

  这篇文章简单的说了下怎么去用网站调用后台去批量执行进程重启,然后用数据库的表做一个简单的互斥量,防止多个用户同时操作。

django搭建一个小型的服务器运维网站-重启服务器的进程的更多相关文章

  1. django搭建一个小型的服务器运维网站-查看服务器中的日志与前端的datatable的利用

    目录 项目介绍和源码: 拿来即用的bootstrap模板: 服务器SSH服务配置与python中paramiko的使用: 用户登陆与session; 最简单的实践之修改服务器时间: 查看和修改服务器配 ...

  2. django搭建一个小型的服务器运维网站-拿来即用的bootstrap模板

    目录 项目介绍和源码: 拿来即用的bootstrap模板: 服务器SSH服务配置与python中paramiko的使用: 用户登陆与session; 最简单的实践之修改服务器时间: 查看和修改服务器配 ...

  3. django搭建一个小型的服务器运维网站-查看和修改服务器配置与数据库的路由

    目录 项目介绍和源码: 拿来即用的bootstrap模板: 服务器SSH服务配置与python中paramiko的使用: 用户登陆与session; 最简单的实践之修改服务器时间: 查看和修改服务器配 ...

  4. django搭建一个小型的服务器运维网站-用户登陆与session

    目录 项目介绍和源码: 拿来即用的bootstrap模板: 服务器SSH服务配置与python中paramiko的使用: 用户登陆与session; 最简单的实践之修改服务器时间: 查看和修改服务器配 ...

  5. django搭建一个小型的服务器运维网站

    前言   不管是运维还是开发抑或是测试,工作中不免会和Linux服务器打交道,常见的操作譬如:查看CPU或内存状态.查看和修改服务器时间.查看或者修改服务器配置文件.实时查看或回看系统的日志.重启服务 ...

  6. 10分钟搭建一个小型网页(python django)(hello world!)

    10分钟搭建一个小型网页(python django)(hello world!) 1.安装django pip install django 安装成功后,在Scripts目录下存在django-ad ...

  7. 初学django搭建一个通讯录应用

    ---恢复内容开始--- django搭建一个通讯录应用 一.环境介绍 window10 64位 Django-1.5.12 python 2.7 Sqlite3 二.基本安装 python2.7安装 ...

  8. 30分钟搭建一个小型网站框架(python django)

    最近因为要做一个小型的网站,需求很简单有点像公司内部的管理网站,和室友一起倒腾,发现了一些坑.我自己之前没有接触过python 但是发现真的非常好上手. 我们没人会前端,所以最怕修改网页,一开始选择了 ...

  9. 用django搭建一个简易blog系统(翻译)(一)

    Django 入门 原始网址: http://www.creativebloq.com/netmag/get-started-django-7132932 代码:https://github.com/ ...

随机推荐

  1. Wildfly安装以及集成idea(mac)

    文章目录 Linux发布运行 下载 集成idea Linux发布运行 首先说一下在linux环境,只需要将war包上传到wildfly-8.2.0.Final/standalone/deploymen ...

  2. SQL标量函数

    调用 MS SQL 标量值函数,应该在函数前面加上 "dbo.",否则会报 “不是可以识别的 内置函数名称”错误.例如 DECLARE @WhichDB TINYINT;     ...

  3. Pikachu漏洞练习平台实验——RCE(五)

    1.概述 RCE(Remote Command/Code Execute) 给攻击者向后台服务器远程注入操作系统命令或者代码,从而控制后台系统. 远程系统命令执行一般出现这种漏洞,是因为应用系统从设计 ...

  4. python之从文件中按行读取数据

    #!/usr/bin/env python3 # -*- coding: utf-8 -*- __author__ = 'jiangwenwen' # 从文件中按行读取数据 file = open(& ...

  5. 次小生成树(Prim + Kruaskal)

    问题引入: 我们先来回想一下生成树是如何定义的,生成树就是用n - 1条边将图中的所有n个顶点都连通为一个连通分量,这样的边连成子树称为生成树. 最小生成树很明显就是生成树中权值最小的生成树,那么我们 ...

  6. AC自动机题单

    AC自动机题目 真的超级感谢xzy 真的帮到我很多 题单 [X] [luogu3808][模板]AC自动机(简单版) https://www.luogu.org/problemnew/show/P38 ...

  7. CSV的规范与使用

    CSV可以通过Excel打开,数据格式比较小,通过记事本打开一个CSV文件, 便知道在csv里面,每一个单元格的数据都是通过逗号来分割的.所以在csv里面切记:单元格数据不要出现逗号 格式: 第一行: ...

  8. 【JMeter5.0】Mac安装JDK和JMeter5

    之前讲了Windows下安装JDK和JMeter4.0的方法,其实不论操作系统是Windows.Mac OS.Linux等,JMeter所需要的基础环境配置都是类似的,本文介绍JMeter for M ...

  9. Java 8实战之读书笔记二:基础知识

    好记性不如烂笔头,整理一些个人觉得比较重要的东西. 一.基础知识 第1章 为什么要关心Java 8 Java 8提供了一个新的API(称为"流", Stream),它支持许多处理数 ...

  10. CSS-01 CSS代码标准和规范

    一:代码规范 1.所有的书写都是在英文半角下进行 2.统一用table键进行缩进 3.属性值必须带引号(单引和双引都可以) 4.p,dt,h标签里不能嵌套块属性标签 5.a标签不能嵌套a 二:文件命名 ...