PYTHON通过跳板机巡检CENTOS的简单实现

实现的细节和引用的文件和以前博客记录的基本一致

https://shaka.blog.csdn.net/article/details/106927633

差别在于,这次是通过跳板机登陆获取的主机信息,只记录差异的部份

1.需要在跳板机相应的路径放置PYTHON的脚本resc.py

resc.py这个脚本中有引用的文件(pm.sh,diskpnum.sh)和以前的记录一样,不再重复列出

这个脚本接受一个参数,IP地址,django一端的服务器将通过SSH连接,并将参数传递给脚本执行

脚本将返回包含CPU,内存,磁盘信息的字典,因为不同主机的磁盘分区名称和数量的不一致性,带有磁盘信息的这个KEY的值,将是一个LIST

# -*- coding: utf-8 -*-
import os,sys
import paramiko
import time
import sys
reload(sys)
import os
import json
import multiprocessing
import signal
sys.setdefaultencoding('utf-8')class TimeoutException(Exception):passdef timeout_handler(signum, frame):raise TimeoutException("error")def sshreinfos(ips):try:redict = {}paramiko.util.log_to_file("/yourreexecpath/paramiko.log")ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())pkey = paramiko.RSAKey.from_private_key_file("/home/user/.ssh/id_rsa")ssh.connect(hostname=ips, port=22, username='sshuser', pkey=pkey, timeout=5)t = ssh.get_transport()sftp=paramiko.SFTPClient.from_transport(t)sftp.put("/yourreexecpath/pm.sh","/tmp/pm.sh")sftp.put("/yourreexecpath/diskpnum.sh", "/tmp/diskpnum.sh")stdindcpu, stdoutcpu, stderrcpu = ssh.exec_command("top -bn1 | awk '/Cpu/{print $2,$3,$4}' | sed 's/[a-z]//g' | sed 's/ //g' | awk -F',' '{print $1+$2+$3}'")stdinmomeryall, stdoutmomeryall, stderrmomeryall = ssh.exec_command("free -m | awk '{print $2}' | awk 'NR==2{print}'")stdinmomery, stdoutmomery, stderrmomery = ssh.exec_command("sh /tmp/pm.sh")musep = (stdoutmomery.read()).replace("\n", "")cpuusep = (stdoutcpu.read()).replace("\n", "")memoryall = (stdoutmomeryall.read()).replace("\n", "")remark = "正常"try:b = round(float(musep))if int(b) > 80:remark = "评估是否扩内存"except Exception:remark = "NONE"redict["ips"] = ipsredict["stdoutcpu"] = cpuusepredict["stdoutmomeryall"] = memoryallredict["musep"] = musepredict["remark"] = remarkymdhms = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))stdindps, stdoutdps, stderrdps = ssh.exec_command("sh /tmp/diskpnum.sh " + ymdhms)dpnums = (stdoutdps).read().replace("\n", "")# print "1.5$"sftp.get("/tmp/diskusetmp" + ymdhms + ".txt", "/yourreexecpath/"+ips + "diskusetmp" + ymdhms + ".txt")diskinfos = open("/yourreexecpath/"+ips + "diskusetmp" + ymdhms + ".txt", 'r')disklists = []for lines in diskinfos:diskitems = {}cons = lines.split()diskitems["pt"] = cons[0].strip()diskitems["pttotal"] = cons[1].strip()diskitems["ptuse"] = cons[2].strip()disklists.append(diskitems)diskinfos.close()os.remove("/yourreexecpath/"+ips + "diskusetmp" + ymdhms + ".txt")redict["disklists"] = disklistsssh.close()return redictexcept:#print "error"return "error"if __name__ == "__main__":if len(sys.argv) != 2:print "argv must be one"exit()ips = sys.argv[1]signal.signal(signal.SIGALRM, timeout_handler)signal.alarm(10) # set timeout to 10 secondstry:print sshreinfos(ips)except TimeoutException:print("error")

2.django一端的实现如下:

views.py对应的方法

用户点击不同的按钮选择是打印到WEB页面,还是打印到WEB页面+下载巡检报告的EXCEL表格

request.POST.has_key('chkaproc')或request.POST.has_key('chkonlylists')
def chkosinfos(request):if request.method=="POST":sqlstr = request.POST.get("sqlstr")filenames=""if request.POST.has_key('chkaproc'):try:import f5.sysinfos#filenames,relists=f5.sysinfos.receivewebsqlstr(sqlstr)relists=f5.sysinfos.remoterelists(sqlstr)filenames=f5.sysinfos.remotereexcel(relists)except Exception:return render(request,"exportsysinfos.html",{"login_err":"SYSINFOSFAILSTEP1"})return render(request,"exportsysinfos.html",{"login_err":"downloadlink:http://web服务器IP地址(存放文件用,程序将文件生成到指定的web虚拟目录):9999/"+filenames,"templist":relists})if request.POST.has_key('chkonlylists'):try:import f5.sysinfosrelists=f5.sysinfos.remoterelists(sqlstr)except Exception:return render(request,"exportsysinfos.html",{"login_err":"SYSINFOSFAILSTEP1"})return render(request,"exportsysinfos.html",{"login_err":"OKAY"+filenames,"templist":relists})else:return render(request,"exportsysinfos.html",{"login_err":"no set"})

views.py引用的两个方法

remoterelists返回多个服务器巡检信息的list
remotereexcel将信息写入excel        

# -*- coding: utf-8 -*-
import os,sys
#sys.setdefaultencoding('utf8')
import paramiko
import xlsxwriter
import time
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
from multiprocessing import Process,Manager
import multiprocessing
import os
import jsondef sshconn():try:ssh = paramiko.SSHClient()ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())#ssh.connect(hostname=self.f5ips, port=22, username=self.usernames, password=self.passwords)pkey = paramiko.RSAKey.from_private_key_file("D:\\idrsapath\\id_rsa")ssh.connect(hostname="serveripaddress", port=22, username='sshuser', pkey=pkey, timeout=5)#连接跳板机return sshexcept Exception:return "error"def remoterelists(sqlstrs):relists=[]iplists = []for line in sqlstrs.splitlines():con = line.split()names = con[0].strip()iplists.append(names)try:ssh=sshconn()for ips in iplists:print ipsstart_time = time.time()try:stdindcmd, stdoutcmd, stderrcmd=ssh.exec_command("/usr/bin/python /yourreexecpath/resc.py " + ips)ipsdict=stdoutcmd.read().replace("\n", "")#.decode('utf-8')end_time = time.time()if end_time - start_time > 10:continueif ipsdict != "error":relists.append(eval(ipsdict))except:print "error remotecmds"passssh.close()return relistsexcept:print "connect sshserver error"return "error"def remotereexcel(excellists):nowtime=time.strftime('%Y-%m-%d-%H-%M-%S',time.localtime(time.time()))+""filenames=nowtime+'systeminfo.xlsx'workbook1 = xlsxwriter.Workbook(".\\uploads\\"+filenames)worksheet = workbook1.add_worksheet()t1='服务器运行情况'format=workbook1.add_format()#worksheet.set_column(0,15,20)format.set_bold()yellow=workbook1.add_format({'align':'center','valign':'vcenter','font_size':22,'fg_color':'FFC1C1'})yellow.set_bold()# worksheet.merge_range(0,0,0,4,t1,yellow)worksheet.merge_range('A1:I1',t1,yellow)worksheet.set_row(0, 38)worksheet.set_column("A:A",20)worksheet.set_column("B:B",11)worksheet.set_column("C:C",12)worksheet.set_column("D:D",12)worksheet.set_column("E:E",20)title=[u'IP地址',u'CPU使用率%',u'内存总量',u'内存使用率%',u'巡检结果']format=workbook1.add_format()format=workbook1.add_format({'align':'center','valign':'vcenter'})format.set_bold()worksheet.write_row('A2',title,format)worksheet.set_row(1, 25)row=2try:for lines in excellists:try:worksheet.write(row,0,lines["ips"])worksheet.write(row,1,lines["stdoutcpu"])worksheet.write(row,2,lines["stdoutmomeryall"])worksheet.write(row,3,lines["musep"])remark="正常"try:b=round(lines["musep"])if int(b)>80:remark="评估是否扩内存"except Exception:remark="NONE"worksheet.write(row,4,remark)ymdhms=time.strftime('%Y%m%d%H%M%S',time.localtime(time.time()))n=5for diskpts in lines["disklists"]:worksheet.set_column(n,n,20)worksheet.write(row,n,"分区 "+diskpts["pt"].strip())worksheet.set_column(n+1,n+1,20)worksheet.write(row,n+1,"分区大小 "+diskpts["pttotal"].strip())worksheet.set_column(n+2,n+2,20)try:dps=round(float(diskpts["ptuse"].strip()))if int(dps)>80:formatmred = workbook1.add_format({'bold': True, 'font_color': 'red'})worksheet.write(row,n+2,"分区使用率 "+diskpts["ptuse"].strip(),formatmred)else:worksheet.write(row,n+2,"分区使用率 "+diskpts["ptuse"].strip())except Exception:worksheet.write(row,n+2,"分区使用率未获取数据")n=n+3except Exception:print lines["ips"] +" error"worksheet.write(row,0,lines["ips"])worksheet.write(row,1,"none")worksheet.write(row,2,"none")worksheet.write(row,3,"none")row=row+1except Exception:print "cannot get datas"return "error"return filenames

3.HTML页面将用户需要巡检的IP列表粘贴到输入框,一行一个IP

html的写法,不怎么会写,只是先写个实现

<!DOCTYPE html>
<html lang="en">
<head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>EXPORTHISTORYVALUES</title>
</head>
<body><div id="container" class="cls-container"><div id="bg-overlay" ></div><div class="cls-header cls-header-lg"><div class="cls-brand"><h3>主机巡检并导出信息</h3>每行一个IP</div></div><div class="cls-content"><div class="cls-content-sm panel"><div class="panel-body"><form id="loginForm" action="{% url 'chkosinfos' %}" method="POST"> {% csrf_token %}<div class="form-group"><div class="input-group"><div class="input-group-addon"><i class="fa fa-user"></i></div><textarea type="text" class="form-control" name="sqlstr" placeholder="主机巡检并导出信息,每行一个IP" style="width:600px;height:111px"></textarea></br></div></div></br></br>
<button class="btn btn-success btn-block" type="submit" name="chkaproc"><b>CHK+EXCEL下载链接</b></button></br></br><button class="btn btn-success btn-block" type="submit" name="chkonlylists"><b>CHK不需要EXCEL,仅网页展示</b></button><h4 style="color: #ff0000"><b>{{ login_err }}</b></h4>{% for row in templist %}
<td>IP:{{ row.ips }}</td></br>
<td><div style="color:{% if row.stdoutcpu|floatformat:"0"|add:"0" >= 50 %}red{% else %}black{% endif %}">CPU使用率:{{ row.stdoutcpu }}</div></td></br>
<td>内存总量M:{{ row.stdoutmomeryall }}</td></br>
<td><div style="color:{% if row.musep|floatformat:"0"|add:"0" >= 90 %}red{% else %}black{% endif %}"> 内存使用率:{{ row.musep }} </div> </td></br>
{% if 'disklists' in row %}
{% for diskrows in row.disklists %}
<td><div style="color:{% if diskrows.ptuse|floatformat:"0"|add:"0" >= 90 %}red{% else %}black{% endif %}"> 分区名称:{{ diskrows.pt }}  分区容量:{{ diskrows.pttotal }}  分区
{#                        <h4 style="color: red"><b>{{ login_err }}</b></h4>#}</form></div></div></div></div>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/621193.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

查询速度提升15倍!银联商务基于 Apache Doris 的数据平台升级实践

本文导读&#xff1a; 在长期服务广大规模商户的过程中&#xff0c;银联商务已沉淀了庞大、真实、优质的数据资产数据&#xff0c;这些数据不仅是银联商务开启新增长曲线的基础&#xff0c;更是进一步服务好商户的关键支撑。为更好提供数据服务&#xff0c;银联商务实现了从 H…

EI级 | Matlab实现VMD-TCN-LSTM变分模态分解结合时间卷积长短期记忆神经网络多变量光伏功率时间序列预测

EI级 | Matlab实现VMD-TCN-LSTM变分模态分解结合时间卷积长短期记忆神经网络多变量光伏功率时间序列预测 目录 EI级 | Matlab实现VMD-TCN-LSTM变分模态分解结合时间卷积长短期记忆神经网络多变量光伏功率时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.【E…

Springboot3新特性:开发第一个 GraalVM 本机应用程序(完整教程)

在讲述之前&#xff0c;各位先自行在网上下载并安装Visual Studio 2022&#xff0c;安装的时候别忘了勾选msvc 概述&#xff1a;GraalVM 本机应用程序&#xff08;Native Image&#xff09;是使用 GraalVM 的一个特性&#xff0c;允许将 Java 应用程序编译成本机二进制文件&am…

AI-数学-高中-5.求函数解析式(4种方法)

原作者视频&#xff1a;函数】3函数解析式求法&#xff08;易&#xff09;_哔哩哔哩_bilibili 1.已知函数类型-待定系数法&#xff1a;先用待定系数法把一次或二次函数一般表达式写出来&#xff1b;再用“要变一起变”左右两边同时替换&#xff0c;计算出一般表达式的常数&…

SpringIOC之support模块GenericGroovyApplicationContext

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

【c++】利用嵌套map创建多层树结构

通常树的深度都大于1&#xff0c;即树有多层&#xff0c;而树结构又可以用c的map容器来实现&#xff0c;所以&#xff0c;本文给出了一种多层树结构的实现思路&#xff0c;同时也给出了相应的c代码。 整体思路概述 首先定义一个节点类Node类&#xff0c;要包括children&#x…

FineBI实战项目一(17):热门商品Top10分析开发

点击新建组件&#xff0c;创建热门商品Top10组件。 选择柱状图&#xff0c;拖拽cnt&#xff08;总数&#xff09;到横轴&#xff0c;拖拽goodName到纵轴。 选择排序规则。 修改横轴和纵轴的标签名称 切换到仪表板&#xff0c;拖拽组件到仪表板 效果如下&#xff1a;

代码随想录算法训练营第四天|24. 两两交换链表中的节点,19.删除链表的倒数第N个节点,面试题 02.07. 链表相交,142.环形链表II,总结

系列文章目录 代码随想录算法训练营第一天|数组理论基础&#xff0c;704. 二分查找&#xff0c;27. 移除元素 代码随想录算法训练营第二天|977.有序数组的平方 &#xff0c;209.长度最小的子数组 &#xff0c;59.螺旋矩阵II 代码随想录算法训练营第三天|链表理论基础&#xff…

【计算机二级考试C语言】C数据类型

C 数据类型 在 C 语言中&#xff0c;数据类型指的是用于声明不同类型的变量或函数的一个广泛的系统。变量的类型决定了变量存储占用的空间&#xff0c;以及如何解释存储的位模式。 C 中的类型可分为以下几种&#xff1a; 序号类型与描述1基本数据类型 它们是算术类型&#x…

Vue3 父组件传值给子组件+以及使用NModal组件

前言&#xff1a;我想实现表格中点击详情弹窗出一个表格展示该行详细信息。想着这个弹窗里用子组件展示。分担父组件下&#xff0c;怕代码过多。&#xff08;使用NModal组件弹窗展示&#xff09; 等我一波百度&#xff0c;嗯&#xff0c;实现方法挺多嘛&#xff0c;什么refs什…

SpringMVC RESTful

文章目录 1、RESTful简介a>资源b>资源的表述c>状态转移 2、RESTful的实现3、HiddenHttpMethodFilter 1、RESTful简介 REST&#xff1a;Representational State Transfer&#xff0c;表现层资源状态转移。 a>资源 资源是一种看待服务器的方式&#xff0c;即&…

大数据深度学习卷积神经网络CNN:CNN结构、训练与优化一文全解

文章目录 大数据深度学习卷积神经网络CNN&#xff1a;CNN结构、训练与优化一文全解一、引言1.1 背景和重要性1.2 卷积神经网络概述 二、卷积神经网络层介绍2.1 卷积操作卷积核与特征映射卷积核大小多通道卷积 步长与填充步长填充 空洞卷积&#xff08;Dilated Convolution&…

详解Spring事件监听

第1章&#xff1a;引言 大家好&#xff0c;我是小黑。今天咱们来聊下Spring框架中的事件监听。在Java里&#xff0c;事件监听听起来好像很高大上&#xff0c;但其实它就像是我们日常生活中的快递通知&#xff1a;当有快递到了&#xff0c;你会收到一个通知。同样&#xff0c;在…

YOLOv8原理与源码解析

课程链接&#xff1a;https://edu.csdn.net/course/detail/39251 【为什么要学习这门课】 Linux创始人Linus Torvalds有一句名言&#xff1a;Talk is cheap. Show me the code. 冗谈不够&#xff0c;放码过来&#xff01;代码阅读是从基础到提高的必由之路。 YOLOv8 基于先前…

解决JuPyter500:Internal Server Error问题

目录 一、问题描述 二、问题分析 三、解决方法 四、参考文章 一、问题描述 在启动Anaconda Prompt后&#xff0c;通过cd到项目文件夹启动Jupyter NoteBook点击.ipynb文件发生500报错。 二、问题分析 base环境下输入指令&#xff1a; jupyter --version 发现jupyter环境…

maven管理使用

maven基本使用 一、简介二、配置文件三、项目结构maven基本标签实践(例子) 四、pom插件配置五、热部署六、maven 外部手动加载jar打包方式Maven上传私服或者本地 一、简介 基于Ant 的构建工具,Ant 有的功能Maven 都有,额外添加了其他功能.本地仓库:计算机中一个文件夹,自己定义…

springboot学生信息管理系统

&#x1f345;点赞收藏关注 → 私信领取本源代码、数据库&#x1f345; 本人在Java毕业设计领域有多年的经验&#xff0c;陆续会更新更多优质的Java实战项目希望你能有所收获&#xff0c;少走一些弯路。&#x1f345;关注我不迷路&#x1f345;一 、设计说明 1.1研究背景 随着…

【rust/bevy】从game template开始

目录 说在前面步骤进入3D控制方块问题 说在前面 操作系统&#xff1a;win11rust版本&#xff1a;rustc 1.77.0-nightlybevy版本&#xff1a;0.12 步骤 rust安装 这里 windows下建议使用msvc版本bevy安装 这里clone代码git clone https://github.com/NiklasEi/bevy_game_templa…

Chapter 8 怎样使用类和对象(下篇)

⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️⚡️ 8.2 对象数组 1.对象数组的每一个元素都是同类的对象 2.在建立数组时&#xff0c;同样…

听觉障碍应该找哪些专业人士?如何获得这些职业?

如果您有听觉障碍的困扰可以寻求以下专业人士的帮助。如果你有兴趣从事听力学职业&#xff0c;可以考虑以下 十几个选项&#xff1a; 1. 临床听力学家 临床听力学家检查患者以诊断他们的听力、平衡或耳朵相关问题。他们与所有年龄段的患者一起工作&#xff0c;或专门针对特定群…