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.rhkb.cn/news/237607.html

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

相关文章

Abaqus汉化教程

用钢铁意志&#xff0c;成就不平凡人生。 今天博主整理了一下Abaqus2023汉化教程&#xff0c;希望大家学习。 第一步&#xff0c;在在菜单栏找到Abaqus CAE右键打开文件所在的位置 第二步&#xff1a;继续右键Abaqus CAE右键打开文件所在的位置 第三步&#xff1a;然后进入到…

RIS 辅助无线网络:基于模型、启发式和机器学习の优化方法

目录 abstractintroduction相关研究BACKGROUND AND PROBLEM FORMULATIONS FOR OPTIMIZING RIS-AIDED WIRELESS NETWORKSA 优化RIS-AIDED无线网络的背景和问题公式RIS操作原则&#xff1a;RIS控制&#xff1a;RIS部署 B 总速率/容量最大化C 功率最小化D 能源效率最大化E 用户公平…

设计模式——1_4 外观(Facade)

文章目录 定义图纸一个例子&#xff1a;自动生成一杯茶沏茶的流程组合方式一&#xff1a;直接组合方法二&#xff1a;外观 碎碎念多个外观对象外观和封装外观和单例姑妄言之 定义 为子系统中的一组接口提供一个一致的界面&#xff0c;外观模式定义了一个高层接口&#xff0c;这…

【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…

自动驾驶apollo9.0 Dreamview Debug方法

Apollo 9.0 安装&编译方法 # 拉取源码 git clone gitgithub.com:ApolloAuto/apollo.git git checkout v9.0.0# 启动docker bash docker/scripts/dev_start.sh bash docker/scripts/dev_into.sh# 编译project ./apollo.sh build默认启动方式 default mode wget https:…

在海绵城市建设中,低功耗遥测终端有哪些独特的优势?

近年来&#xff0c;随着物联网技术的迅猛发展&#xff0c;数据监测和传输已经成为各行各业不可或缺的环节。在诸多特殊环境中因供电问题、潮湿、不便进入等诸多原因&#xff0c;需要一款功耗低、数据传输稳定&#xff0c;防潮抗锈蚀的低功耗遥测终端。 为满足这一需求&#xf…

统信UOS操作系统上禁用IPv6

原文链接&#xff1a;统信UOS操作系统上禁用IPv6 hello&#xff0c;大家好啊&#xff01;继之前我们讨论了如何在麒麟KYLINOS上禁用IPv6之后&#xff0c;今天我要给大家带来的是在统信UOS操作系统上禁用IPv6的方法。IPv6是最新的网络通信协议&#xff0c;但在某些特定的网络环境…

计算机三级(网络技术)——综合题(Sniffer抓包分析)

考点内容&#xff1a; DNS域名解析TCP三次握手FTP(文件传输协议)ICMP(Internet控制报文协议)&#xff1a;ping、tracertHTTP(超文本传输协议)&#xff1a;get、post命令 例题一 下图是校园网某台主机在命令行模式下执行某个命令时用sniffer捕获的数据包。 抓包分析 5~8行为…

RibbonGroup 添加QRadioButton

RibbonGroup添加QRadioButton&#xff1a; QRadioButton * pRadio new QRadioButton(tr("Radio")); pRadio->setToolTip(tr("Radio")); groupClipboard->addWidget(pRadio); connect(pRadio, SIGNAL(clicked(…

Redis分布式锁--java实现

文章目录 Redis分布式锁方案&#xff1a;SETNX EXPIRE基本原理比较好的实现会产生四个问题 几种解决原子性的方案方案&#xff1a;SETNX value值是&#xff08;系统时间过期时间&#xff09;方案&#xff1a;使用Lua脚本(包含SETNX EXPIRE两条指令)方案&#xff1a;SET的扩展…

RSIC-V“一芯”学习笔记(二)——Linux入门教程

文章目录 一、前言二、Busybox套件三、重要的追踪工具——strace四、Shell五、正则表达式六、重定向&#xff08;多次输入测试时&#xff09;七、一些组合命令八、自动化脚本九、学会查阅十、亲&#xff08;yuan&#xff09;近(li) bai du十一、不要逃避困难十二、重视小问题 一…

设计模式之解释器模式【行为型模式】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档> 学习的最大理由是想摆脱平庸&#xff0c;早一天就多一份人生的精彩&#xff1b;迟一天就多一天平庸的困扰。各位小伙伴&#xff0c;如果您&#xff1a; 想系统/深入学习某…

(南京观海微电子)——色温介绍

色温是表示光线中包含颜色成分的一个计量单位。从理论上说&#xff0c;黑体温度指绝对黑体从绝对零度&#xff08;&#xff0d;273℃&#xff09;开始加温后所呈现的颜色。黑体在受热后&#xff0c;逐渐由黑变红&#xff0c;转黄&#xff0c;发白&#xff0c;最后发出蓝色光。当…

经典目标检测YOLO系列(二)YOLOv2算法详解

经典目标检测YOLO系列(二)YOLOv2算法详解 YOLO-V1以完全端到端的模式实现达到实时水平的目标检测。但是&#xff0c;YOLO-V1为追求速度而牺牲了部分检测精度&#xff0c;在检测速度广受赞誉的同时&#xff0c;其检测精度也饱受诟病。正是由于这个原因&#xff0c;YOLO团队在20…

修改SSH默认端口,使SSH连接更安全

以CentOS7.9为例&#xff1a; 1、修改配置文件 vi /etc/ssh/sshd_config 2、远程电脑可连接&#xff0c;暂时将SELinux关闭 # 查询状态 getenforce # 关闭 setenforce 0 # 开启 setenforce 1 3、SELinux设置&#xff08;如果启用&#xff09;&#xff0c;semanage管理工具安…

Python教程(24)——全方位解析Python中的装饰器

Python装饰器是一种特殊的函数&#xff0c;它接收一个函数作为参数&#xff0c;然后返回一个新的函数&#xff0c;用于扩展或修改原始函数的行为。装饰器提供了一种便捷的方式来在不修改被装饰函数源代码的情况下&#xff0c;增加、修改或包装函数的功能。通俗点说就是尽量不修…

12.2内核空间基于SPI总线的OLED驱动

在内核空间编写SPI设备驱动的要点 在SPI总线控制器的设备树节点下增加SPI设备的设备树节点&#xff0c;节点中必须包含 reg 属性、 compatible 属性、 spi-max-frequency 属性&#xff0c; reg 属性用于描述片选索引&#xff0c; compatible属性用于设备和驱动的匹配&#xff…

【MATLAB源码-第111期】基于matlab的SCMA系统误码率仿真,采用polar码编码,输出误码率曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 SCMA&#xff08;Sparse Code Multiple Access&#xff09;系统是一种先进的多用户多输入多输出&#xff08;MU-MIMO&#xff09;通信系统&#xff0c;它采用了一种独特的多址访问技术&#xff0c;旨在提高无线通信网络的效率…

C语言实现快排核心思想(双指针法)

核心代码&#xff1a; 这就是每一趟快排的实现代码&#xff0c;由上面的动图&#xff0c;我们能知道前后指针法的核心是玩好cur和prev这两个指针&#xff0c;具体的逻辑是cur找比key小的值&#xff0c;找到就prev&#xff0c;然后prev和cur的值就进行交换&#xff0c;但是总不能…

通过shell脚本确定当前平台

shell中的变量OSTYPE存储操作系统的名称&#xff0c;也可以使用uname命令来确认当前所在的平台。 shell中的变量HOSTTYPE存储操作系统的架构。 测试代码如下所示&#xff1a; #! /bin/bashecho "use OSTYPE:" if [[ "$OSTYPE" "linux-gnu&quo…