实时Linux性能监控脚本:周期性自动统计CPU、内存和IO使用情况

本文主要是介绍实时Linux性能监控脚本:周期性自动统计CPU、内存和IO使用情况,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Linux Shell 脚本实现每3秒钟统计 CPU 占用率、内存空间、IO、单核 CPU 占用率、CPU 占用率最高的前10个应用进程以及指定目录 /opt 的磁盘空间变化。

Shell脚本

#!/bin/bash# 输出文件路径
OUTPUT_FILE="/var/log/system_monitor.log"# 创建/清空输出文件
> $OUTPUT_FILE# 获取 CPU 核心数量
NUM_CPUS=$(grep -c ^processor /proc/cpuinfo)# 获取 CPU 占用率
function get_cpu_usage() {# 使用 `mpstat` 工具获取所有 CPU 的占用率CPU_USAGE=$(mpstat 1 1 | awk '/^Average:/ {print 100 - $NF}')echo "CPU Usage: ${CPU_USAGE}%"
}# 获取内存使用情况
function get_memory_usage() {# 使用 `free` 命令获取内存使用情况MEM_INFO=$(free -m | awk '/Mem:/ {print $3 "MB used, " $4 "MB free"}')echo "Memory Usage: ${MEM_INFO}"
}# 获取 IO 使用情况
function get_io_usage() {# 使用 `iostat` 获取 IO 使用率IO_INFO=$(iostat -dx 1 1 | awk '/^Device:/ {getline; print $1 " IO Utilization: " $NF"%"}')echo "IO Usage: ${IO_INFO}"
}# 获取单核 CPU 占用率
function get_per_cpu_usage() {# 使用 `mpstat` 工具获取每个 CPU 核心的占用率PER_CPU_USAGE=$(mpstat -P ALL 1 1 | awk '/^Average:/ && $2 ~ /[0-9]+/ {print "CPU" $2 ": " 100 - $NF "%"}')echo "Per CPU Usage:"echo "$PER_CPU_USAGE"
}# 获取 CPU 占用率最高的前 10 个进程
function get_top_10_cpu_processes() {# 使用 `ps` 命令按 CPU 占用率排序,列出前10个进程TOP_PROCESSES=$(ps -eo pid,user,comm,%cpu,%mem --sort=-%cpu | head -n 11)echo "Top 10 CPU-consuming processes:"echo "$TOP_PROCESSES"
}# 获取指定目录的磁盘空间使用情况
function get_disk_usage() {# 使用 `df` 命令获取指定目录的磁盘使用情况DISK_USAGE=$(df -h /opt | awk 'NR==2 {print "Disk Usage on /opt: " $3 " used, " $4 " free, " $5 " utilized"}')echo "$DISK_USAGE"
}# 循环每3秒钟采集一次数据
while true; do# 获取当前时间echo "-----------------------------------------" >> $OUTPUT_FILEecho "Timestamp: $(date)" >> $OUTPUT_FILEecho "-----------------------------------------" >> $OUTPUT_FILE# 获取并输出 CPU 占用率echo "$(get_cpu_usage)" >> $OUTPUT_FILE# 获取并输出内存使用情况echo "$(get_memory_usage)" >> $OUTPUT_FILE# 获取并输出 IO 使用情况echo "$(get_io_usage)" >> $OUTPUT_FILE# 获取并输出每个核心的 CPU 占用率echo "$(get_per_cpu_usage)" >> $OUTPUT_FILE# 获取并输出 CPU 占用率最高的前10个进程echo "$(get_top_10_cpu_processes)" >> $OUTPUT_FILE# 获取并输出指定目录的磁盘空间使用情况echo "$(get_disk_usage)" >> $OUTPUT_FILE# 等待3秒钟再执行下一次采集sleep 3
done

实现思路

  1. 输出文件路径:将统计信息写入 /var/log/system_monitor.log 文件中。

  2. 清空输出文件:每次脚本启动时,清空输出文件,以避免将新数据追加到旧数据之后。

  3. 获取 CPU 核心数量:通过读取 /proc/cpuinfo 文件中的信息,统计 CPU 核心数量。

  4. 获取 CPU 占用率:使用 mpstat 命令计算所有 CPU 的平均占用率。mpstat 1 1 表示采样1秒钟,并获取平均数据。

  5. 获取内存使用情况:使用 free -m 命令获取内存使用情况。free 命令可以显示系统中内存的使用情况,-m 表示以 MB 为单位显示。

  6. 获取 IO 使用情况:使用 iostat 命令获取磁盘 IO 使用率。iostat -dx 1 1 表示采样1秒钟,并获取详细的设备级别的 IO 使用情况。

  7. 获取单核 CPU 占用率:使用 mpstat -P ALL 命令获取每个 CPU 核心的占用率。-P ALL 表示显示所有 CPU 核心的统计信息。

  8. 获取 CPU 占用率最高的前 10 个进程:使用 ps 命令按 CPU 占用率排序,并列出前10个进程。ps -eo pid,comm,%cpu,%mem 显示进程ID、命令名、CPU占用率、内存占用率。--sort=-%cpu 表示按CPU占用率降序排序,head -n 11 显示前10个进程,包含标题行。

  9. 获取指定目录的磁盘空间使用情况:使用 df -h 命令获取指定目录 /opt 的磁盘使用情况。df -h /opt 显示 /opt 目录所在分区的已用空间、可用空间和利用率。

  10. 循环每3秒钟采集一次数据:使用 while true 循环和 sleep 3 命令,确保脚本每3秒钟采集一次数据。

日志文件

日志文件 system_monitor.log 会被持续更新,每次采集到的数据会被追加到该文件中。通过 tail -f /var/log/system_monitor.log 实时查看监控数据。

总结

Shell脚本实现每3秒钟监控系统的 CPU 占用率、内存使用情况、IO使用情况、每个 CPU 核心的占用率、CPU 占用率最高的前10个进程以及 /opt 目录的磁盘空间变化。这有助于实时了解系统和指定目录的性能表现,并在必要时采取措施。

这篇关于实时Linux性能监控脚本:周期性自动统计CPU、内存和IO使用情况的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1120731

相关文章

如何使用celery进行异步处理和定时任务(django)

《如何使用celery进行异步处理和定时任务(django)》文章介绍了Celery的基本概念、安装方法、如何使用Celery进行异步任务处理以及如何设置定时任务,通过Celery,可以在Web应用中... 目录一、celery的作用二、安装celery三、使用celery 异步执行任务四、使用celery

使用Python绘制蛇年春节祝福艺术图

《使用Python绘制蛇年春节祝福艺术图》:本文主要介绍如何使用Python的Matplotlib库绘制一幅富有创意的“蛇年有福”艺术图,这幅图结合了数字,蛇形,花朵等装饰,需要的可以参考下... 目录1. 绘图的基本概念2. 准备工作3. 实现代码解析3.1 设置绘图画布3.2 绘制数字“2025”3.3

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —