shell脚本:统计分析 /home/ 目录用户磁盘使用情况
一、统计单台机器 /home/ 目录下磁盘空间使用 top3 的用户
common.sh 脚本用于统计 /home/* 目录下存储空间 top3 的用户。
du -sb /home/* |sort -nr |head -n 3 #单位为B
二、统计分析多台分布式机器上 /home/ 目录用户磁盘使用情况
#!/bin/sh
# set -x # 打印执行过程 SUBMIT_NODES="submit_nodes.txt"
RESULT="result.txt"
RESULT_TMP="result_tmp.txt"
RESULT_SORTED="result_sorted.txt"
>$RESULT>$RESULT_TMP
>$RESULT_SORTED # 获取机器存储资源占用top3的用户
while read node
do
echo $node
ip=`echo $node | awk '{print $2}'`
hostname=`echo $node | awk '{print $1}'`
# du -sb /home/* |sort -nr |head -n 3 | awk '{print $2}' |awk -F '/' '{print $3}'
sshpass -p GHlsgj123fkjg ssh -p 22 root@$ip ~/common.sh < /dev/null > $RESULT_TMP
# 文本后面追加主机名
sed "s/$/ $hostname/g" $RESULT_TMP >> $RESULT
done < $SUBMIT_NODES while read detail
do
size=`echo $detail | awk '{print $1}'`
user=`echo $detail | awk '{print $2}' | awk -F '/' '{print $3}'`
host=`echo $detail | awk '{print $3}'` # size >20G 则提示存储空间过大
# 10737418240 = 1024*1024*1024
base=21474836480
point=1073741824
if [ $size -gt $base ]
then
ret=""
# 判断用户名是否是纯数字
if echo $user | grep -q '.*[a-zA-Z].*\+$' #user中包含字母,则不是纯数字
then
echo "用户名中包含数字"
else
echo "用户名为纯数字"
fi
# 将size的单位B转换为GB
size_gb=`awk 'BEGIN{printf "%.2f\n",'$size'/'$point'}'`
fi
done < $RESULT_SORTED
三、脚本中各文本存储的内容
submit_nodes.txt 文本为分布式的多台机器的主机名和ip映射关系:
bj01-prd-hdcm12.vivo.lan 10.20.8.44
bj01-prd-hdcm11.vivo.lan 10.20.8.43
bj01-prd-hdcm10.vivo.lan 10.20.8.42
bj01-prd-hdcm09.vivo.lan 10.20.8.41
bj01-prd-hdcm08.vivo.lan 10.20.8.40
result_tmp.txt 文本统计中common.sh 脚本的结果:
/home/lzjiang
/home/bchan
/home/lshen
result.txt 则在 result_tmp.txt 的基础上添加用户所在的主机,内容为:
/home/yi bjthq-dm-submit003.vivo.lan
/home/zqe bjthq-dm-submit003.vivo.lan
/home/lsen bjthq-dm-submit003.vivo.lan
/home/xye bjthq-dm-submit002.vivo.lan
/home/lmie bjthq-dm-submit002.vivo.lan
/home/lpliu bjthq-dm-submit002.vivo.lan
/home/lzjiang bjthq-dm-submit001.vivo.lan
/home/bchn bjthq-dm-submit001.vivo.lan
/home/lhen bjthq-dm-submit001.vivo.lan
result_sorted.txt 文本为根据空间大小降序排序后的结果:
/home/hbxie bjthq-dm-submit024.vivo.lan
/home/bhuag bjthq-dm-submit025.vivo.lan
/home/lzjang bjthq-dm-submit001.vivo.lan
/home/lmxie bjthq-dm-submit015.vivo.lan
/home/mxzhao bj01-prd-hdcm01.vivo.lan
shell脚本:统计分析 /home/ 目录用户磁盘使用情况的更多相关文章
- Shell脚本中实现切换用户并执行命令操作【转】
第一种方法 cat test.sh #!/bin/bashsu - test <<EOFpwd;exit;EOF 执行结果图: 第二种方法 当然也可以用下面的命令来执行 复制代码代码如下: ...
- (转)通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加
通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加 原文:http://www.21yunwei.com/archives/4773 有一个朋友问我如何批量创建用户和设置密码 , ...
- Shell脚本实现检测某ip网络畅通情况,实战用例
Shell脚本实现检测某ip网络畅通情况,实战用例 环境准备,linux shell 发送email 邮件:1.安装sendmailyum -y install sendmail安装好sendmail ...
- Shell脚本中怎么实现用户切换实现操作
当我们在服务器上面疯狂的进行操作的时候,我们用shell脚本来帮我们来完成一些基本的任务,但是一些命令或者一些操作需要我们不断切换用户来实现的话,在shell脚本就不那么好实现了,那么我们在shell ...
- shell脚本 批量转换目录下文件编码
发布:JB01 来源:脚本学堂 [大 中 小] 分享一例shell脚本,实现可以批量转换目录下的文件编码,很实用的一个小shell,有需要的朋友参考下.原文地址:http://www.jb ...
- 学习Shell脚本编程(目录)
所涉及的内容如下: Shell命令行的运行 编写.修改权限和执行Shell程序的步骤 在Shell程序中使用参数和变量 表达式比较.循环结构语句和条件结构语句 在Shell程序中使用函数和调用其他Sh ...
- jenkins中使用shell脚本必须切换jenkins用户
https://blog.csdn.net/cdnight/article/details/81078191 安装这篇解决的 正确使用脚本的方式: 1.脚本必须使用jenknins用户,且所有命令必须 ...
- 获取shell脚本自身所在目录的Shell脚本分享
前几天写的七牛的参赛demo,用bash写了一个便捷安装的脚本,涉及到了路径相关的判断,从stackoverflow,加上自己的实践整理一下. 简单版 下面是一个最简单的实现,可以解决大多数问题,缺陷 ...
- 【shell脚本练习】判断用户存在和用户类型
题目 写一个脚本 1. 传递一个参数给脚本,此参数为用户名: 2. 如果用户存在,则执行如下任务 * 如果用户的id号小于500,显示其为管理员或系统用户: * 否则,显示其为普通用户: 3. 如果用 ...
随机推荐
- java 中的 Math.round(-1.5) 等于多少?(未完成)
java 中的 Math.round(-1.5) 等于多少?(未完成)
- windows下通过批处理脚本启动redis
三种启动方式的特点: 第一种方式 :根目录之命令窗口启动 特点:每次启动都要进入到redis的根目录,比较繁琐,并且占用一个窗口 第二种方式:bat脚本便捷启动 特点:可放在桌面便捷启动,占用窗口 第 ...
- bug是前端还是后端
分析bug是前端还是后端的 如何分析一个bug是前端还是后端的? 平常提bug的时候,前端开发和后端开发总是扯皮,不承认是对方的bug这种情况很容易判断,先抓包看请求报文,对着接口文档,看请求报文 ...
- Java入门第二季——第4章 多态
第4章 多态 多态性是允许你将父对象设置成为和一个或更多的他的子对象相等的技术,赋值之后,父对象就可以根据当前赋值给它的子对象的特性以不同的方式运作 4-1 Java 中的多态 注意:不能通过父类的引 ...
- jvm crash分析
问题描述:线上进程异常退出,查看服务器端日志,有jvm crash文件生成 # # A fatal error has been detected by the Java Runtime Enviro ...
- 浅谈script中的defer与async
一直没有在script上使用过别的属性,今天看基础代码才发现这个,搜索.记录下,以便记忆. 大家都知道,js加载会造成阻塞,阻碍页面的继续渲染. defer: js与页面同步加载,不阻碍页面渲染,会在 ...
- mysql自增主键清零方法
MySQL数据库自增主键归零的几种方法 如果曾经的数据都不需要的话,可以直接清空所有数据,并将自增字段恢复从1开始计数: truncate table table_name; 1 当用户没有trunc ...
- C++关键字——register
register修饰符暗示编译程序相应的变量将被频繁地使用,如果可能的话,应将其保存在CPU的寄存器中,以加快其存储速度.例如下面的内存块拷贝代码, #ifdef NOSTRUCTASSIGN mem ...
- (十八)链接数据库,QSqlTableModel
QMYSQL——mysql QSQLITE——sqlite QOICQ——orcale 所需头文件 .pro增加 sql #include <QSqlDatabase> #include ...
- vue-quill-editor的用法
1. main.js引入vue-quill-editor import VueQuillEditor from 'vue-quill-editor' import 'quill/dist/quill. ...