Linux 性能监控之CPU&内存&I/O监控Shell脚本2

简介: Linux 性能监控之CPU&内存&I/O监控Shell脚本2

Linux性能监控之CPU&内存&I/O监控Shell脚本2

 


思路:

捕获数据->停止捕获数据->提取数据

备注:一些命令的输出,第一次记录的数据是自重启到当前时间的平均值,所以,如果采用循环的方式不断重复开启命令,获取的数据可能不太准确,所以,这里采用开启命令后,一次性捕获需要的数据。

 

(一)捕获数据

用法:sh capture.sh arg1 arg2

参数说明:arg1为采样频率,arg2为采样时长,单位都为秒

例子:2秒采集一次数据,采样时长10秒,共采样5

sh capture.sh 2 10

 

capture.sh内容如下:

#!/bin/bash

count=$(($2/$1))

echo $count

rm -f top.txt

rm -f vmstat.txt

rm -f iostat.txt

 

{ top -bd $1 -n $count >> top.txt; }&

{ vmstat -t -n -S K $1 $count >> vmstat.txt; }&

{ iostat -kx $1 $count >> iostat.txt; }&

 

wait

exit 0

说明:并发执行采集数据命令

 

(二)停止捕获数据

用法:sh stop.sh

说明:如果停止压测时还没到命令自动退出时间,可执行该脚本,停止数据捕获

 

stop.sh脚本内容如下:

#!/bin/bash

killall top

killall vmstat

killall iostat

exit 0

 

(三)提取数据

用法:sh analyze.sh agr1 arg2 arg3 arg4 arg5

参数说明:agr1agr2agr3分别为capture中指定的存储文件,默认分别为top.txtvmstat.txt,iostat.txt,arg4为网卡接口,arg需要采集的进程(COMMAND)

例子:

sh analyze.sh top.txt vmstat.txt iostat.txt eth1 netns

 

analyze.sh内容如下:

#!/bin/bash

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

IP=`ifconfig $4 | grep "inet addr" | cut -f 2 -d ":" | cut -f 1 -d " "`

echo "IP地址:"$IP

 

#获取cpu总核数

cpu_num=`grep -c "model name" /proc/cpuinfo`

echo "cpu总核数:"$cpu_num

printf "\n"

 

# 1、获取CPU利用率

printf "获取cpu利用率\n"

printf "cpu_user\tcpu_system\tcpu_idle\tcpu_iowait\ttime\n"

 

record_num=`grep Cpu $1| wc -l`

for((i=1;i<=$record_num;i++))

do

#获取时间

time=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "当前时间"$time

 

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

cpu_user=`grep Cpu $1 | awk '{print $2}' |sed -n ${i}"p"| cut -f 1 -d "%"`

#echo "用户空间占用CPU百分比:"$cpu_user

 

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

cpu_system=`grep Cpu $1 | awk '{print $3}' |sed -n ${i}"p" | cut -f 1 -d "%"`

#echo "内核空间占用CPU百分比:"$cpu_system

 

#获取空闲CPU百分比

cpu_idle=`grep Cpu $1 | awk '{print $5}' |sed -n ${i}"p" | cut -f 1 -d "%"`

#echo "空闲CPU百分比:"$cpu_idle

 

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

cpu_iowait=`grep Cpu $1 | awk '{print $3}' |sed -n ${i}"p" | cut -f 1 -d "%"`

#echo "等待输入输出占CPU百分比:"$cpu_iowait

#echo $cpu_user " "$cpu_system " " $cpu_idle " " $cpu_iowait

printf "%.1f\t\t%.1f\t\t%.1f\t\t%.1f\t\t%s\n" $cpu_user $cpu_system $cpu_idle $cpu_iowait $time

done

printf "\n"

 

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

printf "获取cpu中断和上下文切换次数\n"

printf "cpu_interrupt\tcpu_context_switch\ttime\n"

 

record_num=`cat $2 | wc -l`

for((i=3;i<=$record_num;i++))

do

#获取时间

time=`sed -n ${i}"p" $2 | awk '{print $19}'`

#echo "当前时间"$time

 

#获取CPU中断次数

cpu_interrupt=`sed -n ${i}"p" $2 | awk '{print $11}'`

#echo "CPU中断次数:"$cpu_interrupt

 

#获取CPU上下文切换次数

cpu_context_switch=`sed -n ${i}"p" $2 | awk '{print $12}'`

#echo "CPU上下文切换次数:"$cpu_context_switch

 

printf "%d\t\t%d\t\t\t%s\n" $cpu_interrupt $cpu_context_switch $time

done

printf "\n"

 

#3、获取CPU负载信息

printf "\n获取CPU负载信息-1551分钟前到现在的负载均值\n"

printf "cpu_load_15min\tcpu_load_5min\tcpu_load_1min\ttime\n"

 

record_num=`grep "load average" $1 | wc -l`

for((i=1;i<=$record_num;i++))

do

#获取时间

time=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "当前时间"$time

 

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

cpu_load_15min=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $12}' | cut -f 1 -d ','`

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

 

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

cpu_load_5min=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $11}' | cut -f 1 -d ','`

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

 

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

cpu_load_1min=`grep "load average"  $1 | sed -n ${i}"p" | awk '{print $10}' | cut -f 1 -d ','`

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

 

printf "%.2f\t\t%.2f\t\t%.2f\t\t%s\n" $cpu_load_15min $cpu_load_5min $cpu_load_1min $time

done

 

printf "获取CPU负载信息-cpu队列长度\n"

printf "cpu_task_length\ttime\n"

 

record_num=`cat $2 | wc -l`

for((i=3;i<=$record_num;i++))

do

#获取时间

time=`sed -n ${i}"p" $2 | awk '{print $19}'`

#echo "当前时间"$time

 

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

cpu_task_length=`sed -n ${i}"p" $2 | awk '{print $1}'`

#echo "CPU任务队列长度:"$cpu_task_length

 

printf "%d\t\t%s\n" $cpu_task_length $time

done

printf "\n"

 

#4、获取内存信息

printf "获取内存信息\n"

printf "mem_total\tmem_sys_used\tmem_sys_free\tmem_user_used\tmem_user_free\tmem_buffers\tmem_swap_total\tmem_swap_used\tmem_swap_free\tmem_swap_cached\ttime\n"

 

record_num=`grep Mem $1 | wc -l`

for((i=1;i<=$record_num;i++))

do

#获取时间

time=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "当前时间"$time

 

#获取物理内存总量

mem_total=`grep Mem $1 | sed -n ${i}"p" | awk '{print $2}' | cut -f 1 -d 'k'`

#echo "物理内存总量:"$mem_total

 

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

mem_sys_used=`grep Mem $1 | sed -n ${i}"p" | awk '{print $4}' | cut -f 1 -d 'k'`

#echo "已使用内存总量(操作系统)"$mem_sys_used

 

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

mem_sys_free=`grep Mem $1 | sed -n ${i}"p" | awk '{print $6}' | cut -f 1 -d 'k'`

#echo "剩余内存总量(操作系统)"$mem_sys_free

 

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

mem_buffers=`grep Mem $1 | sed -n ${i}"p" | awk '{print $8}' | cut -f 1 -d 'k'`

mem_swap_cached=`grep Swap $1 | sed -n ${i}"p" | awk '{print $8}' | cut -f 1 -d 'k'`

mem_user_used=$(($mem_sys_used-$mem_buffers-$mem_swap_cached))

#echo "已使用内存总量(应用程序)"$mem_user_used

 

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

mem_user_free=$(($mem_sys_free+$mem_buffers+$mem_swap_cached))

#echo "剩余内存总量(应用程序)"$mem_user_free

 

#获取交换分区总大小

mem_swap_total=`grep Swap $1 | sed -n ${i}"p" | awk '{print $2}' | cut -f 1 -d 'k'`

#echo "交换分区总大小:"$mem_swap_total

 

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

mem_swap_used=`grep Swap $1 | sed -n ${i}"p" | awk '{print $4}' | cut -f 1 -d 'k'`

#echo "已使用交换分区大小:"$mem_swap_used

 

#获取剩余交换分区大小

mem_swap_free=`grep Swap $1 | sed -n ${i}"p" | awk '{print $6}' | cut -f 1 -d 'k'`

#echo "剩余交换分区大小:"$mem_swap_free

 

printf "%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%d\t\t%s\n" $mem_total $mem_sys_used $mem_sys_free $mem_user_used $mem_user_free $mem_buffers $mem_swap_total $mem_swap_used $mem_swap_free $mem_swap_cached $time

done

printf "\n"

 

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

echo "指定设备(/dev/sda1)的统计信息"

printf "disk_sda_rs\tdisk_sda_ws\tdisk_sda_avgqu_sz\tdisk_sda_await\tdisk_sda_svctn\tdisk_sda_util\ttime\n"

 

record_num=`grep sda $3 | wc -l`

for((i=1;i<=$record_num;i++))

do

#获取时间

time=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "当前时间"$time

 

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

disk_sda_rs=`grep sda $3 | sed -n ${i}"p" | awk '{print $4}'`

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

 

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

disk_sda_ws=`grep sda $3 | sed -n ${i}"p" | awk '{print $5}'`

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

 

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

disk_sda_avgqu_sz=`grep sda $3 | sed -n ${i}"p" | awk '{print $9}'`

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

 

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

disk_sda_await=`grep sda $3 | sed -n ${i}"p" | awk '{print $10}'`

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

 

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

disk_sda_svctm=`grep sda $3 | sed -n ${i}"p" | awk '{print $11}'`

#echo "向设备发起的服务时间均值:"$disk_sda_svctm

 

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

disk_sda_util=`grep sda $3 | sed -n ${i}"p"| awk '{print $12}'`

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

 

printf "%.2f\t\t%.2f\t\t%.2f\t\t\t%.2f\t\t%.2f\t\t%.2f\t\t%s\n" $disk_sda_rs $disk_sda_ws $disk_sda_avgqu_sz $disk_sda_await $disk_sda_svctm $disk_sda_util $time

done

printf "\n"

 

#6、获取某个进程的CPU、内存使用信息

printf "获取某个进程的CPU、内存使用信息\n"

printf "proc_id\tproc_cpu\tproc_mem\tproc_vsz\ttime\n"

 

record_num=`grep $5 $1 | wc -l`

for((i=1;i<=$record_num;i++))

do

#获取时间

time=`grep "load average" $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "当前时间:"$time

 

#获取进程ID

proc_id=`grep $5 $1 | sed -n ${i}"p" | awk '{print $1}'`

#echo "进程ID"$proc_id

 

#获取进程CPU使用率

proc_cpu=`grep $5 $1 | sed -n ${i}"p" | awk '{print $3}'`

#echo "进程CPU使用率:"$proc_cpu

 

#获取进程内存使用率

proc_mem=`grep $5 $1 | sed -n ${i}"p" | awk '{print $4}'`

#echo "进程内存使用率:"$proc_mem

 

#获取进程虚拟内存总量

proc_vsz=`grep $5 $1 | sed -n ${i}"p" | awk '{print $5}'`

#echo "进程使用的虚拟内存总量:"$proc_vsz

 

printf "%d\t\t%.1f\t\t%.1f\t\t%d\t\t%s\n" $proc_id $proc_cpu $proc_mem $proc_vsz $time

done

 

注:获取磁盘I/O统计信息,这里收集的时间数据是大致时间-top取样时的时间,非精确时间,有可能存在较大误差

 

 

效果如下:

 




 

注:针对不同类型、版本的操作系统,以上脚本可能需要做适当修改才可适用

附脚本下载地址:Linux 性能监控之CPU&内存&I/O监控Shell脚本2.zip

 

 

目录
相关文章
|
2月前
|
存储 安全 Unix
七、Linux Shell 与脚本基础
别再一遍遍地敲重复的命令了,把它们写进Shell脚本,就能一键搞定。脚本本质上就是个存着一堆命令的文本文件,但要让它“活”起来,有几个关键点:文件开头最好用#!/usr/bin/env bash来指定解释器,并用chmod +x给它执行权限。执行时也有讲究:./script.sh是在一个新“房间”(子Shell)里跑,不影响你;而source script.sh是在当前“房间”里跑,适合用来加载环境变量和配置文件。
397 9
|
2月前
|
存储 Shell Linux
八、Linux Shell 脚本:变量与字符串
Shell脚本里的变量就像一个个贴着标签的“箱子”。装东西(赋值)时,=两边千万不能有空格。用单引号''装进去的东西会原封不动,用双引号""则会让里面的$变量先“变身”再装箱。默认箱子只能在当前“房间”(Shell进程)用,想让隔壁房间(子进程)也能看到,就得给箱子盖个export的“出口”戳。此外,Shell还自带了$?(上条命令的成绩单)和$1(别人递进来的第一个包裹)等许多特殊箱子,非常有用。
273 2
|
2月前
|
算法 Linux Shell
Linux实用技能:打包压缩、热键、Shell与权限管理
本文详解Linux打包压缩技巧、常用命令与原理,涵盖.zip与.tgz格式操作、跨系统传文件方法、Shell运行机制及权限管理,助你高效使用Linux系统。
Linux实用技能:打包压缩、热键、Shell与权限管理
|
4月前
|
Web App开发 缓存 安全
Linux一键清理系统垃圾:释放30GB空间的Shell脚本实战​
这篇博客介绍了一个实用的Linux系统盘清理脚本,主要功能包括: 安全权限检查和旧内核清理,保留当前使用内核 7天以上日志文件清理和系统日志压缩 浏览器缓存(Chrome/Firefox)、APT缓存、临时文件清理 智能清理Snap旧版本和Docker无用数据 提供磁盘空间使用前后对比和大文件查找功能 脚本采用交互式设计确保安全性,适合定期维护开发环境、服务器和个人电脑。文章详细解析了脚本的关键功能代码,并给出了使用建议。完整脚本已开源,用户可根据需求自定义调整清理策略。
487 1
|
6月前
|
Linux Shell
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
Centos或Linux编写一键式Shell脚本删除用户、组指导手册
187 4
|
6月前
|
Linux Shell 数据安全/隐私保护
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
Centos或Linux编写一键式Shell脚本创建用户、组、目录分配权限指导手册
371 3
|
7月前
|
Linux Shell
shell_42:Linux参数移动
总的来说,参数移动是Linux shell脚本中的一个重要概念,掌握它可以帮助我们更好地处理和管理脚本中的参数。希望这个解释能帮助你理解和使用参数移动。
150 18
|
Shell 索引
shell脚本入门到实战(四)- 数组
shell脚本入门到实战(四)- 数组
147 0
|
Shell
shell脚本入门到实战(三) - 变量
shell脚本入门到实战(三) - 变量
171 0
|
Shell Linux 人机交互
shell脚本入门到实战(二)--shell输入和格式化输出
shell脚本入门到实战(二)--shell输入和格式化输出
687 0

热门文章

最新文章