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>
相关文章:

PYTHON通过跳板机巡检CENTOS的简单实现
实现的细节和引用的文件和以前博客记录的基本一致 https://shaka.blog.csdn.net/article/details/106927633 差别在于,这次是通过跳板机登陆获取的主机信息,只记录差异的部份 1.需要在跳板机相应的路径放置PYTHON的脚本resc.py resc.py这个脚本中有引用的文件(pm.sh,diskpn…...
网络配置以及命令详解
传统linux中,网络接口为eth0,eth1,eth2,..... RHEL 7以上版本默认命名是基于分配上的固定名称,ens33 接口类型: en:以太网有线接口 wl:无线局域网接口 ww:无线广域网 dmesg:显示开机信息 适配器类型: s:热插拔插槽 o:板载 p:pci类型 ifconfig ens160(命令行配置,临时生效):查…...
商务外语MR混合现实仿真情景实训教学
MR混合现实技术是一种将虚拟世界与真实世界相结合的技术。通过MR设备,我们可以将虚拟的场景、人物、物品等元素实时地呈现在真实的环境中,实现真实与虚拟的完美融合。在商务外语的实训教学中,MR技术可以为我们提供丰富的场景资源,…...

牛客周赛 Round 28 解题报告 | 珂学家 | 组合数学 + 离散化树状数组
前言 整体评价 还是E稍微有点意思,新周赛好像比预期要简单一些, _. 欢迎关注 珂朵莉 牛客周赛专栏 珂朵莉 牛客小白月赛专栏 A. 小红的新周赛 思路: 模拟 #include <bits/stdc.h>using namespace std;int main() {int res 0;for (int i 0; i < 6; i…...
Python系列(3)—— 变量
变量 一、变量命名规范二、变量赋值三、变量的数据类型四、变量的作用域五、变量类型转换 Python编程中,变量是存储数据的容器。它们用于存储各种数据类型,如整数、浮点数、字符串、列表、字典等。理解变量及其工作原理是Python编程的基础。 一、变量命…...
Java 并发性和多线程2
四、如何创建并运行 java 线程 Java 线程类也是一个 object 类,它的实例都继承自 java.lang.Thread 或其子类。 可以用如下方式用 java 中创建一个线程: Tread thread new Thread(); 执行该线程可以调用该线程的 start()方法: thread.start(); 在上…...

最新消息:OpenAI GPT Store 正式上线,GPTs 应用商店来了!
原文链接 https://openaigptguide.com/gpt-store-and-chatgpt-team/ OpenAI推出的两款新产品和服务:GPT Store和ChatGPT Team,提供了许多全新的解决方案和功能,旨在帮助用户更轻松地使用和构建GPT工具,同时也增加了公司的收入来源…...

memory泄露分析方法(java篇)
#memory泄露主要分为java和native 2种,本文主要介绍java# 测试每天从monkey中筛选出内存超标的app,提单流转到我 首先,辨别内存泄露类型(java,还是native) 从采到的dumpsys_meminfo_pid看java heap&…...

kubectlkubeletrancherhelmkubeadm这几个命令行工具是什么关系?
背景 在最近学习k8s的过程中,发现kubectl&kubelet&rancher&helm&kubeadm这几个命令怎么在交错使用,他们究竟是什么关系?他们分别应该在什么情况下使用呢?这里我进行了简单的总结,做个区分。 各工具说…...
Day26 669修剪二叉搜索树 108有序数组转为二叉搜索树 538二叉搜索树转换为累加树
669 修剪二叉搜索树 给定一个二叉搜索树,同时给定最小边界L 和最大边界 R。通过修剪二叉搜索树,使得所有节点的值在[L, R]中 (R>L) 。你可能需要改变树的根节点,所以结果应当返回修剪好的二叉搜索树的新的根节点。 class Solution { pub…...

优化CentOS 7.6的HTTP隧道代理网络性能
在CentOS 7.6上,通过HTTP隧道代理优化网络性能是一项复杂且细致的任务。首先,我们要了解HTTP隧道代理的工作原理:通过建立一个安全的隧道,HTTP隧道代理允许用户绕过某些网络限制,提高数据传输的速度和安全性。然而&…...
第二篇ts,es6箭头函数结合typescript,和for...of
1.基本用法: const f v > v// 等同于const f function(v) {return v}2.箭头函数返回数组 const f () > {const list [1,2,3]// 直接返回一个对象return list.map(it > ({id: it}))}const result f() // [{id:1},{id:2},{id:3}]3.箭头函数和变量解构结合使用 cons…...
异构多品牌高清视频监控接入-技术方案
目 录 一、概述 二、建设目标及需求 (一)建设总目标 (二)需求分析 三、设计依据与设计原则 (一)设计依据 (二)设计原则 1、先进性与适用性 2、经济性与实用性 3、可靠性与安全性 4、开放性 5、可扩充性 6、追求最优化的系统设备配置 7、提高监管…...
编程探秘:Python深渊之旅-----机器学习入门(七)
团队决定在他们的项目中加入一些机器学习功能。瑞宝,对新技术充满好奇,跃跃欲试地想了解更多。 瑞宝(兴奋地):我一直想学习机器学习,现在终于有机会了! 龙(微笑着)&…...

SpringMVC 学习博客记录
文章目录 Servlet请求转发和请求包含RequestDispatcher HandlerInterceptor组件实际运用场景 HandlerMapping&RequestMappingInfo(HandlerMapping)HandlerExecutionChainHandlerAdapter源码学习知识点博客记录 Servlet请求转发和请求包含 RequestDispatcher Request#getR…...

重磅!OpenAI正式发布,自定义ChatGPT商店!
1月11日凌晨,OpenAI在官网正式发布了,自定义GPT商店,可以帮助用户找到目前最好用、流行的自定义ChatGPT助手。 在2024年第一季度,OpenAI将启动GPT 开发者收入计划。首先,美国地区的开发者将根据用户对其 GPT 的使用情…...

LeetCode讲解篇之47. 全排列 II
文章目录 题目描述题解思路题解代码 题目描述 题解思路 初始化一个nums中元素是否被访问的数组used、记录还需要递归的深度deep 遍历nums 如果当前元素被访问过或者当前元素等于前一个元素且前一个元素没被访问过就跳过该次遍历 否则选择当前元素,继续递归 直到…...

机器学习~从入门到精通(二)线性回归算法和多元线性回归
为什么要做数据归一化 一、数据归一化: 1.最值归一化 2.均值方差归一化import numpy as npX np.random.randint(1,100,size100) X X.reshape(-1,2) X.shape X np.array(X,dtypefloat) X[:,0] (X[:,0]-np.min(X[:,0]))/(np.max(X[:,0])-np.min(X[:,0])) X[:,1]…...
IPv6组播--PIM
IPv6组播路由协议 PIM(IPv6)作为一种IPv6网络中的组播路由协议,主要用于将网络中的组播数据流引入到有组播数据请求的组成员所连接的路由器上,从而实现组播数据流的路由查找与转发。 PIM(IPv6)协议包括PIM-SM(IPv6)和PIM-DM(IPv5)两种模式 IPv6组播协议定义 PIM(…...

如何在Spring Boot中使用EhCache缓存
1、EhCache介绍 在查询数据的时候,数据大多来自于数据库,我们会基于SQL语句与数据库交互,数据库一般会基于本地磁盘IO将数据读取到内存,返回给Java服务端,我们再将数据响应给前端,做数据展示。 但是MySQL…...

C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...

Spark 之 入门讲解详细版(1)
1、简介 1.1 Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架。Spark在2013年6月进入Apache成为孵化项目,8个月后成为Apache顶级项目,速度之快足见过人之处&…...
React hook之useRef
React useRef 详解 useRef 是 React 提供的一个 Hook,用于在函数组件中创建可变的引用对象。它在 React 开发中有多种重要用途,下面我将全面详细地介绍它的特性和用法。 基本概念 1. 创建 ref const refContainer useRef(initialValue);initialValu…...

练习(含atoi的模拟实现,自定义类型等练习)
一、结构体大小的计算及位段 (结构体大小计算及位段 详解请看:自定义类型:结构体进阶-CSDN博客) 1.在32位系统环境,编译选项为4字节对齐,那么sizeof(A)和sizeof(B)是多少? #pragma pack(4)st…...
FFmpeg 低延迟同屏方案
引言 在实时互动需求激增的当下,无论是在线教育中的师生同屏演示、远程办公的屏幕共享协作,还是游戏直播的画面实时传输,低延迟同屏已成为保障用户体验的核心指标。FFmpeg 作为一款功能强大的多媒体框架,凭借其灵活的编解码、数据…...
WEB3全栈开发——面试专业技能点P2智能合约开发(Solidity)
一、Solidity合约开发 下面是 Solidity 合约开发 的概念、代码示例及讲解,适合用作学习或写简历项目背景说明。 🧠 一、概念简介:Solidity 合约开发 Solidity 是一种专门为 以太坊(Ethereum)平台编写智能合约的高级编…...

USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...

2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
Spring是如何解决Bean的循环依赖:三级缓存机制
1、什么是 Bean 的循环依赖 在 Spring框架中,Bean 的循环依赖是指多个 Bean 之间互相持有对方引用,形成闭环依赖关系的现象。 多个 Bean 的依赖关系构成环形链路,例如: 双向依赖:Bean A 依赖 Bean B,同时 Bean B 也依赖 Bean A(A↔B)。链条循环: Bean A → Bean…...

基于IDIG-GAN的小样本电机轴承故障诊断
目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) 梯度归一化(Gradient Normalization) (2) 判别器梯度间隙正则化(Discriminator Gradient Gap Regularization) (3) 自注意力机制(Self-Attention) 3. 完整损失函数 二…...