shell编程中为何监控磁盘分区的使用,如何操作
Admin 2022-05-19 群英技术资讯 633 次浏览
当然我们是不希望发生此类问题的,如果网站总出现不稳定或打不开情况,会给用户一种不靠谱的感觉。所以,对于磁盘分区的使用,我们需要实时监控,当超过预设值时,就发送份邮件或短信给管理员,将错误扼杀至摇篮里。
对于此脚本的编写是很简单的,主要一点就是获取到磁盘分区的使用率。我们知道df命令可以列出各个分区的空间使用情况:
# df Filesystem 1K-blocks Used Available Use% Mounted on devtmpfs 3986648 0 3986648 0% /dev tmpfs 3999984 0 3999984 0% /dev/shm tmpfs 3999984 528 3999456 1% /run tmpfs 3999984 0 3999984 0% /sys/fs/cgroup /dev/vda1 41931756 17576208 24355548 42% / /dev/vdb1 52403200 476572 51926628 1% /data /dev/vdb2 104806400 29255772 75550628 28% /www tmpfs 799996 0 799996 0% /run/user/0 /dev/vdb3 52402180 398576 52003604 1% /mnt
我们可以看到各个分区的空间使用情况。然后接口grep命令以及awk命令,过滤掉其他信息,只留下各个分区的使用情况信息。
我们只想得到以/dev/开头的分区信息
# df | grep ^/dev /dev/vda1 41931756 17576264 24355492 42% / /dev/vdb1 52403200 476572 51926628 1% /data /dev/vdb2 104806400 29255980 75550420 28% /www /dev/vdb3 52402180 398576 52003604 1% /mnt
然后继续使用awk命令过滤不想要的信息
# df | grep ^/dev | awk '{print $1":"$5}' /dev/vda1:42% /dev/vdb1:1% /dev/vdb2:28% /dev/vdb3:1%
拿到各个分区的使用率后,下面就是对其进行循环遍历,依次判断各个分区的使用情况。
下面给出完成的代码:
#!/bin/bash # 监控分区的空间使用情况,超过预设值告警 export PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:~/bin export LANG=en # 分区空间使用率阀值 USE_LIM=70 while ((1)) do disks=$( df | grep ^/dev | awk '{print $1":"$5}') for disk in $disks do used=$(echo $disk | cut -d: -f2 | cut -d'%' -f1) if [ "$used" -ge "$USE_LIM" ];then # 调用告警脚本,这里直接用echo来替代了 echo "$(echo $disk | cut -d: -f1) is used $used%" fi done sleep 10 done
注意:一般我们服务器上用的语系都是英文的,特别是在编写shell脚本的时候,建议加上这样一行
export LANG=en
因为我们是要做实时的监控,所以脚本里使用了死循环,表示此脚本不会停会一直循环执行。当然,执行速度也是要做限制的,不然占用太多服务器资源就不太好了。所以这里使用了sleep 10,表示10秒监控一次。
另外这里还要一点需要注意,就是过滤掉百分号%。这里我们使用了cut命令来过滤掉%,然后拿到纯数字型的分区使用率和预设值做比较。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
在linux中,可以使用“grep 查找内容 文件”命令来简单查找文件内容;如果想要忽略大小写,则可使用“grep -i 查找内容 文件”命令;如果想搜索目录里所有文件,且结果中显示行号,则可使用“grep -nr 查找内容 *”命令。
Linux清理系统日志的方法你知道是怎样的吗?带着这个问题,可以来看看小编给大家伙整理的资料,有需要的朋友一定不要错过了这篇文章。
linux查看防火墙状态的方法:1、iptables防火墙,查看防火墙状态,代码为【service iptables status】;2、firewall防火墙,代码为【firewall-cmd --state】。
查看方法:1、利用lsof命令,该命令用于列出系统中已经打开的所有文件,当命令的参数设置为“-i”时,可以列出符合条件的进程,语法为“lsof -i:1433”;2、利用“netstat-aptn”命令,该命令可以直接查看所有已经开启的端口号,直接查找结果有没有1433端口即可。
linux运行级别定义在“/etc/inittab”配置文件中。“/etc/inittab”是linux初始化文件系统时,init初始化程序用到的配置文件;该配置文件只能用来设置系统的默认运行级别,也就是系统开机后会进入那个运行级别。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008