当前位置: 首页 > news >正文

python+flask+mongodb+vue撸一个实时监控linux服务资源的网站

用python+flask+mongodb+vue写一个监控linux服务资源实时使用率的页面网站,并每30秒定时请求,把Linux数据保存数据到mongodb数据库中,监控的linux的资源有:cup、内存、网络带宽、mysql慢查询、redis、系统平均负载、磁盘使用率等,网页需要按照列表形式展示,每30秒刷新最新数据并展示

首先,你需要确保已经安装了Flask,PyMongo,Vue和axios等依赖项。

Python Flask相关代码

我们需要创建一个新的API路由来获取系统资源的详细信息。我们可以使用psutil库来获取系统信息。pymysql库用于获取MySQL的慢查询,redis库用于获取Redis的相关信息。为了方便地计算网络带宽,我们可以使用vnstat库。

在Python Flask应用中,我们可以创建一个新的API路由来获取系统资源的详细信息。

代码示例:

 

from flask import Flask, jsonifyfrom flask_restful import Resource, Apiimport psutilimport vnstatimport pymysqlimport redisapp = Flask(__name__)api = Api(app)class SystemResource(Resource):def get(self):cpu_percent = psutil.cpu_percent(interval=1)memory_info = psutil.virtual_memory()disk_usage = psutil.disk_usage("/")mysql_slow_queries = self.get_mysql_slow_queries()redis_info = self.get_redis_info()network_info = self.get_network_info()system_load = os.getloadavg()return jsonify({"cpu": cpu_percent,"memory": memory_info.percent,"disk": disk_usage.percent,"mysql": mysql_slow_queries,"redis": redis_info,"network": network_info,"system_load": system_load})def get_mysql_slow_queries(self):conn = pymysql.connect(host="localhost", user="username", password="password", db="db")with conn.cursor() as cursor:cursor.execute("SELECT * FROM slow_query_log")result = cursor.fetchall()return resultdef get_redis_info(self):r = redis.Redis(host="localhost", port=6379, db=0)info = r.info()return infodef get_network_info(self):stats = vnstat.read_totals("/path/to/vnstat.db")total_bytes_sent = stats[0]["TX"]total_bytes_received = stats[0]["RX"]current_date_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")return {"total_bytes_sent": total_bytes_sent,"total_bytes_received": total_bytes_received,"current_date_time": current_date_time}api.add_resource(SystemResource, "/system")if __name__ == "__main__":app.run(debug=True)

以上Python Flask代码将在根URL下创建一个新资源,并在该资源中返回系统的CPU、内存、磁盘、MySQL慢查询、Redis信息、网络和系统负载详细信息。

Vue相关代码

我们可以创建一个Vue组件,该组件包含一个表格,表格中的每一行都代表一种类型的系统资源。我们可以使用axios库来从上述Python Flask API获取数据,并在表格中显示这些数据。

 

<template><div><table><thead><tr><th>资源类型</th><th>百分比使用率</th></tr></thead><tbody><tr v-for="(resource, index) in resources" :key="index"><td>{{ resource.type }}</td><td>{{ resource.percentage }}</td></tr></tbody></table></div></template><script>export default {name: "SystemMonitor",data() {return {resources: []};},mounted() {this.getResources();},methods: {getResources() {axios.get("/system").then(response => {this.resources = response.data;}).catch(error => {console.error(error);});}}};</script>

在以上代码中,我们使用了一个Vue组件,该组件有一个表格,表格中的每一行都有一个资源类型和相应的使用率百分比。当我们加载此组件时,我们调用getResources方法来获取系统资源信息并显示它们。

对于每30秒刷新数据的需求,你可以使用JavaScript的setInterval函数来设置一个定时器,每次触发时都会重新获取系统资源信息并更新表格内容。


mounted() {this.getResources();setInterval(() => {this.getResources();}, 30000); // 每30秒执行一次},

这样就可以创建一个能够实时监控多种Linux资源并每30秒刷新的页面了。动手尝试一下吧。

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:【文末自行领取】

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Visual Studio(vs)下载安装C/C++运行环境配置和基本使用注意事项
  • Qt_布局管理器
  • Pytorch使用集成可形变卷积构建网络并导出onnx模型
  • 8-----手机机型维修工具助手 功能较全 涵盖解锁 刷机 修复等选项 维修推荐
  • 黑神话悟空+云技术,游戏新体验!
  • 《深度学习》—— 神经网络模型对手写数字的识别
  • 索引的介绍
  • 网页打开时,下载的文件text/html/重定向类型有什么作用?
  • C# 开发教程-中级教程
  • 【Python】耗时任务的超时管理
  • Python 的集合类型
  • 计算机三级网络技术总结(四)
  • Python 从入门到实战22(类的定义、使用)
  • TCP/IP五层模型
  • HBase初探笔记
  • 【108天】Java——《Head First Java》笔记(第1-4章)
  • axios请求、和返回数据拦截,统一请求报错提示_012
  • Bytom交易说明(账户管理模式)
  • crontab执行失败的多种原因
  • idea + plantuml 画流程图
  • IIS 10 PHP CGI 设置 PHP_INI_SCAN_DIR
  • iOS编译提示和导航提示
  • iOS仿今日头条、壁纸应用、筛选分类、三方微博、颜色填充等源码
  • JS进阶 - JS 、JS-Web-API与DOM、BOM
  • js作用域和this的理解
  • Python 反序列化安全问题(二)
  • python3 使用 asyncio 代替线程
  • Python实现BT种子转化为磁力链接【实战】
  • 阿里云应用高可用服务公测发布
  • 从零开始的webpack生活-0x009:FilesLoader装载文件
  • 海量大数据大屏分析展示一步到位:DataWorks数据服务+MaxCompute Lightning对接DataV最佳实践...
  • 看完九篇字体系列的文章,你还觉得我是在说字体?
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 前端攻城师
  • 前嗅ForeSpider采集配置界面介绍
  • 微信开放平台全网发布【失败】的几点排查方法
  • 学习笔记:对象,原型和继承(1)
  • 一起参Ember.js讨论、问答社区。
  • 硬币翻转问题,区间操作
  • 【运维趟坑回忆录】vpc迁移 - 吃螃蟹之路
  • ​iOS安全加固方法及实现
  • ​卜东波研究员:高观点下的少儿计算思维
  • (k8s中)docker netty OOM问题记录
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
  • (附源码)springboot宠物管理系统 毕业设计 121654
  • (官网安装) 基于CentOS 7安装MangoDB和MangoDB Shell
  • (原+转)Ubuntu16.04软件中心闪退及wifi消失
  • 、写入Shellcode到注册表上线
  • .CSS-hover 的解释
  • .gitignore文件---让git自动忽略指定文件
  • .NET CORE Aws S3 使用
  • .Net 访问电子邮箱-LumiSoft.Net,好用
  • .NET 事件模型教程(二)
  • .Net(C#)常用转换byte转uint32、byte转float等