0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何用脚本来获取linux系统CPU、内存、磁盘IO,及原理解释

Linux爱好者 来源:CSDN技术社区 作者:一口Linux 2021-04-08 14:40 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

一、脚本

今天主要分享一个shell脚本,用来获取linux系统CPU、内存、磁盘IO等信息。

#!/bin/bash

# 获取要监控的本地服务器IP地址

IP=`ifconfig | grep inet | grep -vE ‘inet6|127.0.0.1’ | awk ‘{print $2}’`

echo “IP地址:”$IP

# 获取cpu总核数

cpu_num=`grep -c “model name” /proc/cpuinfo`

echo “cpu总核数:”$cpu_num

# 1、获取CPU利用率

################################################

#us 用户空间占用CPU百分比

#sy 内核空间占用CPU百分比

#ni 用户进程空间内改变过优先级的进程占用CPU百分比

#id 空闲CPU百分比

#wa 等待输入输出的CPU时间百分比

#hi 硬件中断

#si 软件中断

#################################################

# 获取用户空间占用CPU百分比

cpu_user=`top -b -n 1 | grep Cpu | awk ‘{print $2}’ | cut -f 1 -d “%”`

echo “用户空间占用CPU百分比:”$cpu_user

# 获取内核空间占用CPU百分比

cpu_system=`top -b -n 1 | grep Cpu | awk ‘{print $4}’ | cut -f 1 -d “%”`

echo “内核空间占用CPU百分比:”$cpu_system

# 获取空闲CPU百分比

cpu_idle=`top -b -n 1 | grep Cpu | awk ‘{print $8}’ | cut -f 1 -d “%”`

echo “空闲CPU百分比:”$cpu_idle

# 获取等待输入输出占CPU百分比

cpu_iowait=`top -b -n 1 | grep Cpu | awk ‘{print $10}’ | cut -f 1 -d “%”`

echo “等待输入输出占CPU百分比:”$cpu_iowait

#2、获取CPU上下文切换和中断次数

# 获取CPU中断次数

cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $11}’`

echo “CPU中断次数:”$cpu_interrupt

# 获取CPU上下文切换次数

cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $12}’`

echo “CPU上下文切换次数:”$cpu_context_switch

#3、获取CPU负载信息

# 获取CPU15分钟前到现在的负载平均值

cpu_load_15min=`uptime | awk ‘{print $11}’ | cut -f 1 -d ‘,’`

echo “CPU 15分钟前到现在的负载平均值:”$cpu_load_15min

# 获取CPU5分钟前到现在的负载平均值

cpu_load_5min=`uptime | awk ‘{print $10}’ | cut -f 1 -d ‘,’`

echo “CPU 5分钟前到现在的负载平均值:”$cpu_load_5min

# 获取CPU1分钟前到现在的负载平均值

cpu_load_1min=`uptime | awk ‘{print $9}’ | cut -f 1 -d ‘,’`

echo “CPU 1分钟前到现在的负载平均值:”$cpu_load_1min

# 获取任务队列(就绪状态等待的进程数)

cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $1}’`

echo “CPU任务队列长度:”$cpu_task_length

#4、获取内存信息

# 获取物理内存总量

mem_total=`free | grep Mem | awk ‘{print $2}’`

echo “物理内存总量:”$mem_total

# 获取操作系统已使用内存总量

mem_sys_used=`free | grep Mem | awk ‘{print $3}’`

echo “已使用内存总量(操作系统):”$mem_sys_used

# 获取操作系统未使用内存总量

mem_sys_free=`free | grep Mem | awk ‘{print $4}’`

echo “剩余内存总量(操作系统):”$mem_sys_free

# 获取应用程序已使用的内存总量

mem_user_used=`free | sed -n 3p | awk ‘{print $3}’`

echo “已使用内存总量(应用程序):”$mem_user_used

# 获取应用程序未使用内存总量

mem_user_free=`free | sed -n 3p | awk ‘{print $4}’`

echo “剩余内存总量(应用程序):”$mem_user_free

# 获取交换分区总大小

mem_swap_total=`free | grep Swap | awk ‘{print $2}’`

echo “交换分区总大小:”$mem_swap_total

# 获取已使用交换分区大小

mem_swap_used=`free | grep Swap | awk ‘{print $3}’`

echo “已使用交换分区大小:”$mem_swap_used

# 获取剩余交换分区大小

mem_swap_free=`free | grep Swap | awk ‘{print $4}’`

echo “剩余交换分区大小:”$mem_swap_free

#5、获取磁盘I/O统计信息

echo “指定设备(/dev/sda)的统计信息”

# 每秒向设备发起的读请求次数

disk_sda_rs=`iostat -kx | grep sda| awk ‘{print $4}’`

echo “每秒向设备发起的读请求次数:”$disk_sda_rs

# 每秒向设备发起的写请求次数

disk_sda_ws=`iostat -kx | grep sda| awk ‘{print $5}’`

echo “每秒向设备发起的写请求次数:”$disk_sda_ws

# 向设备发起的I/O请求队列长度平均值

disk_sda_avgqu_sz=`iostat -kx | grep sda| awk ‘{print $9}’`

echo “向设备发起的I/O请求队列长度平均值”$disk_sda_avgqu_sz

# 每次向设备发起的I/O请求平均时间

disk_sda_await=`iostat -kx | grep sda| awk ‘{print $10}’`

echo “每次向设备发起的I/O请求平均时间:”$disk_sda_await

# 向设备发起的I/O服务时间均值

disk_sda_svctm=`iostat -kx | grep sda| awk ‘{print $11}’`

echo “向设备发起的I/O服务时间均值:”$disk_sda_svctm

# 向设备发起I/O请求的CPU时间百分占比

disk_sda_util=`iostat -kx | grep sda| awk ‘{print $12}’`

echo “向设备发起I/O请求的CPU时间百分占比:”$disk_sda_util

执行结果:

163607f4-97c4-11eb-8b86-12bb97331649.png

二、原理讲解

知其然还要知其所以然,下面详细我们讲解脚本实现的原理。

1. 获取要监控的本地服务器IP地址

IP=`ifconfig | grep inet | grep -vE ‘inet6|127.0.0.1’ | awk ‘{print $2}’`

echo “IP地址:”$IP

ifconfig | grep inet过滤出如下结果包含字符串inet的行,如下图红色圈起来的两行 其中| 是管道的意思,将前面命令的结果作为输入给| 右边的命令

grep -vE ‘inet6|127.0.0.1’将第一步结果通过命令grep -vE过滤掉包含inet6和127.0.0.1的行

将第二步结果通过命令awk 将字符串分割,$n(0~N) 对应相应的参数,如下图多少$2对应地址:192.168.0.125,‘{print $2}’ 打印出$2的值

将第三步的结果赋值给变量IP

echo“IP地址:”$IP打印出变量IP的值,【后面脚本中赋值和打印的语句功能相同,不再重复解释】

16540ce0-97c4-11eb-8b86-12bb97331649.png

2. 获取cpu总核数

cpu_num=`grep -c “model name” /proc/cpuinfo`

echo “cpu总核数:”$cpu_num

在linux的/proc目录下存放了系统运行的很多系统资源信息,其中**/proc/cpuinfo**存放了系统运行时cpu的很多重要信息。

所有的cpu核信息由model name字符串给出,

通过命令grep -c “model name” /proc/cpuinfo 可以计算出文件 /proc/cpuinfo中出现字符串model name出现的次数,就可以得到cpu总核数。-c 表示统计字符串出现次数。

如下所示:

166184c4-97c4-11eb-8b86-12bb97331649.png

3. 获取CPU利用率

top命令经常用来监控linux的系统状况,是常用的性能分析工具,能够实时显示系统中各个进程的资源占用情况。

# 获取用户空间占用CPU百分比

cpu_user=`top -b -n 1 | grep Cpu | awk ‘{print $2}’ | cut -f 1 -d “%”`

echo “用户空间占用CPU百分比:”$cpu_user

# 获取内核空间占用CPU百分比

cpu_system=`top -b -n 1 | grep Cpu | awk ‘{print $4}’ | cut -f 1 -d “%”`

echo “内核空间占用CPU百分比:”$cpu_system

# 获取空闲CPU百分比

cpu_idle=`top -b -n 1 | grep Cpu | awk ‘{print $8}’ | cut -f 1 -d “%”`

echo “空闲CPU百分比:”$cpu_idle

# 获取等待输入输出占CPU百分比

cpu_iowait=`top -b -n 1 | grep Cpu | awk ‘{print $10}’ | cut -f 1 -d “%”`

echo “等待输入输出占CPU百分比:”$cpu_iowait

1680f426-97c4-11eb-8b86-12bb97331649.png

top -b -n 1显示系统的信息并以格式化打印,结果只刷新一次

n 设置退出前屏幕刷新的次数

b 将top输出编排成适合输出到文件的格式,可以使用这个选项创建进程日志

grep Cpu提取出字符串Cpu所在的行

awk ‘{print $2}’ 将第二步得到的字符串分割,并调用方法print 打印出 $2 对应的第二个字符串,0.5%us

cut -f 1 -d “%” 表示以%为分隔符,将第三步的结果分隔开,并显示分割后的记过的第一个字符串即0.5

-d “%” 是以%作为分隔符,

-f 1显示以:分割每一行的第一段内容

其他脚本以此类推

其他Cpu利用率参数含义如下:

#us 用户空间占用CPU百分比

#sy 内核空间占用CPU百分比

#ni 用户进程空间内改变过优先级的进程占用CPU百分比

#id 空闲CPU百分比

#wa 等待输入输出的CPU时间百分比

#hi 硬件中断

#si 软件中断

4.获取CPU上下文切换和中断次数

# 获取CPU中断次数

cpu_interrupt=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $11}’`

echo “CPU中断次数:”$cpu_interrupt

# 获取CPU上下文切换次数

cpu_context_switch=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $12}’`

echo “CPU上下文切换次数:”$cpu_context_switch

# 获取任务队列(就绪状态等待的进程数)

cpu_task_length=`vmstat -n 1 1 | sed -n 3p | awk ‘{print $1}’`

echo “CPU任务队列长度:”$cpu_task_length

vmstat是Virtual Meomory Statistics(虚拟内存统计)的缩写,可对操作系统的虚拟内存、进程、CPU活动进行监控。是对系统的整体情况进行统计,不足之处是无法对某个进程进行深入分析。vmstat -n 1 1只显示一次各字段名称。

-n:只在开始时显示一次各字段名称。

sed -n 3p将第一步的结果打印出第3行

参数说明:

-n或--quiet或--silent 取消自动打印模式空间,仅显示script处理后的结果。

动作说明:

p :打印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~

3.awk ‘{print $1}’` 将第2步结果得出的字符串分割,并打印第一个字符串

169339ba-97c4-11eb-8b86-12bb97331649.png

5、获取CPU负载信息

# 获取CPU15分钟前到现在的负载平均值

cpu_load_15min=`uptime | awk ‘{print $11}’ | cut -f 1 -d ‘,’`

echo “CPU 15分钟前到现在的负载平均值:”$cpu_load_15min

# 获取CPU5分钟前到现在的负载平均值

cpu_load_5min=`uptime | awk ‘{print $10}’ | cut -f 1 -d ‘,’`

echo “CPU 5分钟前到现在的负载平均值:”$cpu_load_5min

# 获取CPU1分钟前到现在的负载平均值

cpu_load_1min=`uptime | awk ‘{print $9}’ | cut -f 1 -d ‘,’`

echo “CPU 1分钟前到现在的负载平均值:”$cpu_load_1min

uptime 命令可以用来查看服务器已经运行了多久,当前登录的用户有多少,以及服务器在过去的1分钟、5分钟、15分钟的系统平均负载值。系统负载是处于可运行runnable或不可中断uninterruptable状态的进程的平均数。可运行状态的进程要么正在使用 CPU 要么在等待使用 CPU。不可中断状态的进程则正在等待某些 I/O 访问,例如等待磁盘 IO。有三个时间间隔的平均值。负载均值的意义根据系统中 CPU 的数量不同而不同,负载为 1 对于一个只有单 CPU 的系统来说意味着负载满了,而对于一个拥有 4 CPU 的系统来说则意味着 75% 的时间里都是空闲的。

参考之前脚本分析,**awk ‘{print $9}’ | cut -f 1 -d ‘,’**将第一步的结果分割开,并得到第9个字符串,然后用‘,’分隔开,并得到分割后的第一个字符串

16a11594-97c4-11eb-8b86-12bb97331649.png

6、获取内存信息

# 获取物理内存总量

mem_total=`free | grep Mem | awk ‘{print $2}’`

echo “物理内存总量:”$mem_total

# 获取操作系统已使用内存总量

mem_sys_used=`free | grep Mem | awk ‘{print $3}’`

echo “已使用内存总量(操作系统):”$mem_sys_used

# 获取操作系统未使用内存总量

mem_sys_free=`free | grep Mem | awk ‘{print $4}’`

echo “剩余内存总量(操作系统):”$mem_sys_free

# 获取应用程序已使用的内存总量

mem_user_used=`free | sed -n 3p | awk ‘{print $3}’`

echo “已使用内存总量(应用程序):”$mem_user_used

# 获取应用程序未使用内存总量

mem_user_free=`free | sed -n 3p | awk ‘{print $4}’`

echo “剩余内存总量(应用程序):”$mem_user_free

# 获取交换分区总大小

mem_swap_total=`free | grep Swap | awk ‘{print $2}’`

echo “交换分区总大小:”$mem_swap_total

# 获取已使用交换分区大小

mem_swap_used=`free | grep Swap | awk ‘{print $3}’`

echo “已使用交换分区大小:”$mem_swap_used

# 获取剩余交换分区大小

mem_swap_free=`free | grep Swap | awk ‘{print $4}’`

echo “剩余交换分区大小:”$mem_swap_free

free 命令显示系统内存的使用情况,包括物理内存、交换内存(swap)和内核缓冲区内存。

grep Swap 将第一步的结果过滤只显示包含字符串Swap的行

awk ‘{print $4}’ 将第二步结果分割,并打印出第四个字符串的值

16cbdfe0-97c4-11eb-8b86-12bb97331649.png

【其他脚本参考前面的分析】

7. 获取磁盘I/O统计信息

echo “指定设备(/dev/sda)的统计信息”

# 每秒向设备发起的读请求次数

disk_sda_rs=`iostat -kx | grep sda| awk ‘{print $4}’`

echo “每秒向设备发起的读请求次数:”$disk_sda_rs

# 每秒向设备发起的写请求次数

disk_sda_ws=`iostat -kx | grep sda| awk ‘{print $5}’`

echo “每秒向设备发起的写请求次数:”$disk_sda_ws

# 向设备发起的I/O请求队列长度平均值

disk_sda_avgqu_sz=`iostat -kx | grep sda| awk ‘{print $9}’`

echo “向设备发起的I/O请求队列长度平均值”$disk_sda_avgqu_sz

# 每次向设备发起的I/O请求平均时间

disk_sda_await=`iostat -kx | grep sda| awk ‘{print $10}’`

echo “每次向设备发起的I/O请求平均时间:”$disk_sda_await

# 向设备发起的I/O服务时间均值

disk_sda_svctm=`iostat -kx | grep sda| awk ‘{print $11}’`

echo “向设备发起的I/O服务时间均值:”$disk_sda_svctm

# 向设备发起I/O请求的CPU时间百分占比

disk_sda_util=`iostat -kx | grep sda| awk ‘{print $12}’`

echo “向设备发起I/O请求的CPU时间百分占比:”$disk_sda_util

iostat命令被用于监视系统输入输出设备和CPU的使用情况。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。

-k:显示状态以千字节每秒为单位,而不使用块每秒

-x:显示扩展状态

grep sda用于过滤第一步得到的结果,只显示包含字符串sda的哪一行

awk ‘{print $4}’ 将第二步的结果分割,并只显示第4个字符串

17440e48-97c4-11eb-8b86-12bb97331649.png

iostat 由 Red Hat Enterprise Linux AS 发布。同时 iostat 也是 Sysstat 的一部分。所以我们安装要安装sysstat。安装 sysstat 包:

sudo apt-get install sysstat
编辑:lyn

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • cpu
    cpu
    +关注

    关注

    68

    文章

    11370

    浏览量

    226391
  • 内存
    +关注

    关注

    9

    文章

    3255

    浏览量

    76589
  • 磁盘
    +关注

    关注

    1

    文章

    403

    浏览量

    26621
  • Shell脚本
    +关注

    关注

    0

    文章

    36

    浏览量

    8562

原文标题:一键获取 Linux 内存、CPU、磁盘IO等信息脚本编写,及其原理详解

文章出处:【微信号:LinuxHub,微信公众号:Linux爱好者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    Linux服务器性能排查完整流程

    Linux服务器性能问题是最让运维工程师头疼的故障之一。服务器响应缓慢、网站打开转圈、数据库查询超时,这些现象背后可能隐藏着CPU打满、内存泄漏、磁盘
    的头像 发表于 05-14 10:42 388次阅读

    Linux服务器性能问题的排查指南

    服务器性能问题通常归结为四类资源瓶颈:CPU内存磁盘 IO、网络。任何性能下降、业务卡顿、响应变慢的背后,都可以追溯到这四个维度的某一个(或多个)达到了瓶颈。
    的头像 发表于 05-12 09:56 367次阅读

    LuatOS的内存分配机制

    不同 LuatOS 硬件平台在内存布局上存在差异,Lua 运行内存系统内存与 PSRAM 扩展内存的分配方式各有区别。部分型号将
    的头像 发表于 04-16 12:37 223次阅读
    LuatOS的<b class='flag-5'>内存</b>分配机制

    如何理解Linux内核中的PCIe驱动

    我们习惯了用 Verilog 去死磕 PCIe 的底层协议状态机。但一旦越过硬件边界来到操作系统层面,Linux 内核是如何接管并驱动这些 PCI/PCIe 设备的呢?由于不同的 CPU 架构实现了
    的头像 发表于 04-11 17:22 1401次阅读

    Linux磁盘空间告警的常见原因和诊断方法

    磁盘空间告警是运维工作中最常见的告警类型之一。当磁盘空间耗尽时,应用程序无法写入日志、数据库无法正常提交、容器无法创建新镜像,甚至系统日志写入失败会导致难以诊断的连锁故障。本文从实际运维经验出发,提供一套完整的
    的头像 发表于 04-08 14:25 201次阅读

    Linux内核三大核心模块深度解析:调度、内存与I/O

    Linux内核作为操作系统的核心,其进程调度、内存管理和文件I/O三大模块共同决定了系统的性能与稳定性。无论是多核服务器的高并发处理,还是嵌入式设备的资源受限场景,深入
    的头像 发表于 03-12 09:00 326次阅读
    <b class='flag-5'>Linux</b>内核三大核心模块深度解析:调度、<b class='flag-5'>内存</b>与I/O

    磁盘IO问题的定位根因与调优解决思路

    、Elasticsearch、Kafka 这类重 IO 业务的机器上。CPU 看着不高,内存也没爆,但系统就是卡得像被冻住了一样——十有八九是磁盘
    的头像 发表于 02-24 14:11 1015次阅读

    Linux磁盘管理指令合集:从查看、分区到修复

    Linux 服务器运维或日常使用中,磁盘管理是高频操作 —— 无论是排查磁盘空间不足的问题,还是新增硬盘后的分区配置,都离不开一系列核心指令。今天就为大家整理一份「Linux
    的头像 发表于 02-03 16:07 3901次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>磁盘</b>管理指令合集:从查看、分区到修复

    【「Linux 设备驱动开发(第 2 版)」阅读体验】+读深入理解Linux内核内存分配

    最近这段时间内存条、硬盘的价格飞涨,随着AI产品的兴起,大数据模型的应用,对硬件存储要求的更高。这节阅读有关Linux内存管理方面的知识。 Linux
    发表于 01-16 20:05

    从小白到大牛:Linux嵌入式系统开发的完整指南

    基础强化:嵌入式开发离不开Linux 系统操作,需熟练掌握命令行(文件操作、进程管理、权限配置)、Shell 脚本编写、Makefile 基础语法。建议通过 “每日一个 Linux
    发表于 12-16 10:42

    Linux性能监控与调优技巧

    作为一名在一线摸爬滚打多年的运维工程师,我见过太多因为性能问题导致的线上故障。凌晨2点被告警电话吵醒,面对CPU飙升到100%、内存不足、磁盘IO瓶颈等问题时的那种焦虑,相信每个运维人
    的头像 发表于 08-18 11:26 1109次阅读

    企业级Linux磁盘维护的完整流程

    在企业级Linux环境中,磁盘故障是导致系统宕机和数据丢失的主要原因之一。据统计,超过70%的企业级服务器故障与存储系统相关。作为运维工程师,掌握完整的
    的头像 发表于 07-23 16:59 1146次阅读

    Linux系统环境监测终极指南

    Linux系统环境主要监测CPU内存磁盘I/O和网络流量。
    的头像 发表于 06-25 14:41 1074次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>系统</b>环境监测终极指南

    Linux系统性能指南

    Linux服务器运行了很多应用,在高负载下,服务器可能会出现性能瓶颈,例如CPU利用率过高、内存不足、磁盘I/O瓶颈等,从而导致系统卡顿,服
    的头像 发表于 06-23 14:12 2009次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>系统</b>性能指南

    Linux系统磁盘分区与挂载详解

    磁盘分区是将物理硬盘划分为不同的逻辑部分,每个分区都可以被视为一个独立的存储设备。通过磁盘分区,我们可以更好地管理磁盘空间,实现数据的组织和隔离。
    的头像 发表于 06-17 15:08 2819次阅读
    <b class='flag-5'>Linux</b><b class='flag-5'>系统</b>中<b class='flag-5'>磁盘</b>分区与挂载详解