当前位置: 首页 > 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秒刷新的页面了。动手尝试一下吧。

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

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


http://www.mrgr.cn/news/30349.html

相关文章:

  • 从 InnoDB 到 Memory:MySQL 存储引擎的多样性
  • 更换UFS绑定固件与“工程固件”的区别 小米10s机型更换cpu绑定包对比 写入以及修复基带
  • 无人机 PX4 飞控 | EKF 使用传感器汇总与添加传感器方法
  • Pytorch使用集成可形变卷积构建网络并导出onnx模型
  • (六)WebAPI方法的调用
  • 学习风格的类型
  • Scrapy爬虫框架 Pipeline 数据传输管道
  • 多线程---线程的状态及常用方法
  • 【9.11最新发布】Win11 24H2 26100.1742 专业版镜像!
  • 解决 Torch not compiled with CUDA enabled 问题 | MiniCPM3-4B 【应用开发笔记】
  • 阅读笔记——《围城》
  • 前后端分离项目中如何保证 API 安全
  • Vue3.0组合式API:computed计算属性、watch监听器、watchEffect高级监听器
  • 小阿轩yx-SaltStack部署与应用基础
  • ABAP-Logger ABAP 日志记录与任何其他语言一样轻松
  • 聊一聊测试用例的重要性
  • PathoDuet: HE 和 IHC 染色病理切片分析的基础模型|文献速递-Transformer架构在医学影像分析中的应用
  • 高校宿舍电费管理怎么实现
  • 【论文阅读】Face2Diffusion for Fast and Editable Face Personalization
  • MySQL数据库