最近使用了个自动化平台(详见自动化运维平台Spug测试)进行每周的变更,效果很不错,平台将大量重复繁琐的操作通过脚本分发方式标准化自动化了,平台核心是下发到各个服务器的shell脚本,感觉有必要对shell脚本做个总结,所以有了写本专题的想法。本专题将结合运维实际介绍shell脚本的各项用法,预计10篇左右,将包括系统巡检、监控、ftp上传下载、数据库查询、日志清理、时钟同步、定时任务等,里面会涉及shell常用语法、注意事项、调试排错等。
二、本文前言本文是该专题的第三篇。
文章主要统计指定目录下排名靠前的目录。生产上文件系统超阀值是很常见的告警项,通过本文的统计脚本可以快速准确的定位超阀值文件系统下使用率较高的目录。
三、环境说明[root@ansible-tower ~]# sh dir_space_calc.sh /var /opt /home /usr
统计/var /opt /home /usr这4个目录下所有目录的大小
2.查看执行结果[root@ansible-tower ~]# more file_space_20210219.log
执行结果输出至日志 file_space_20210219.log,可查看各目录下排名前20的目录具体大小和文件名。
五、ansible方式下发执行1.ansible方式执行[root@ansible-tower ~]# ansible -m script -a "chdir=/tmp /root/dir_space_calc.sh /home /log /usr" test157
使用ansible的script模块执行脚本dir_space_calc.sh,先进入远端服务器test157的/tmp目录,再执行脚本。
2.查看执行结果[root@ansible-tower ~]# ansible -m shell -a 'more /tmp/file_space_20210219.log' test157
此次传参的目录只有3个:/home /log /usr,其中/log目录还不存在,统计结果会忽略不存在的目录。
六、本文总结本文主要介绍了如何快速统计指定目录下的大文件,通过脚本输出的日志可以很方便的定位大文件路径。生产上很多时候都是日志所在文件系统使用率超阀值告警,由于日志一般很多目录层次很深,手动查看劳时费力且容易有疏漏,本文的脚本可完美解决该问题。
本文所有脚本和安装包文件已上传github:shell-scripts-03
更多请点击:shell专题