设为首页 收藏本站
查看: 613|回复: 0

[经验分享] Linux如何查找大文件或目录总结

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-8-31 08:57:47 | 显示全部楼层 |阅读模式
1: 如何查找大文件?
搜索当前目录下,超过100M大小的文件:
1
2
3
4
5
6
7
8
9
10
[iyunv@getlnx01 u03]# find . -type f -size +100M

./usr/local/jdk-7u67-linux-x64.tar.gz
./data/log/charge-service/test-access.log.2016-08-08.log
./data/log/aaa_service/test-access.log.2016-08-09.log
./home/deploy/logs/testmqlogs/otherdays/testmq_client.1.log
./home/deploy/logs/testmqlogs/otherdays/testmq_client.2.log
./opt/backend/charge-service/1.2/shared/console.log
./opt/backend/express_service/0.0.3.tar.gz
./opt/backend/aaa-service/1.2/shared/console.log



更详细显示一些文件属性或信息:
1
2
3
4
5
6
7
8
9
10
11
[iyunv@getlnx01 u03]# find . -type f -size +100M  -print0 | xargs -0 ls -l

-rw-rw-r-- 1 deploy deploy 542795006 8月  30 15:14 ./data/log/charge-service/test-access.log.2016-08-08.log
-rw-rw-r-- 1 deploy deploy 225658142 8月  25 16:28 ./data/log/aaa_service/test-access.log.2016-08-09.log
-rw-rw-r-- 1 deploy deploy 253623621 8月  30 15:15 ./home/deploy/logs/testmqlogs/otherdays/testmq_client.1.log
-rw-rw-r-- 1 deploy deploy 373547598 8月  25 16:28 ./home/deploy/logs/testmqlogs/otherdays/testmq_client.2.log
-rw-rw-r-- 1 deploy deploy 645631934 8月  30 15:15 ./opt/backend/charge-service/1.2/shared/console.log
-rw-rw-r-- 1 deploy deploy 209314900 8月  30 15:15 ./opt/backend/aaa-service/1.2/shared/console.log
-rw-r--r-- 1 root   root   315334884 12月 21 2015 ./opt/backend/express_service/0.0.3.tar.gz
-rw-r--r-- 1 root   root   142376665 6月  11 2015 ./usr/local/jdk-7u67-linux-x64.tar.gz
-rw-rw-r-- 1 deploy deploy 105085974 8月  30 15:15 ./usr/local/push-tomcat/logs/push/info.log6829699375703641.tmp



当我们只需要查找超过100M大小文件,并显示查找出来文件的具体大小,并排序(下)
1
2
3
4
5
6
7
8
9
10
[iyunv@getlnx01 u03]# find . -type f -size +100M  -print0 | xargs -0 du -h
102M     ./usr/local/push-tomcat/logs/push/info.log6829699375703641.tmp
136M     ./usr/local/jdk-7u67-linux-x64.tar.gz
518M     ./data/log/charge-service/test-access.log.2016-08-08.log
216M     ./data/log/aaa_service/test-access.log.2016-08-09.log
242M     ./home/deploy/logs/testmqlogs/otherdays/testmq_client.1.log
357M     ./home/deploy/logs/testmqlogs/otherdays/testmq_client.2.log
616M     ./opt/backend/charge-service/1.2/shared/console.log
301M     ./opt/backend/express_service/0.0.3.tar.gz
201M     ./opt/backend/aaa-service/1.2/shared/console.log



1
2
3
4
5
6
7
8
9
[iyunv@getlnx01 u03]# find . -type f -size +100M  -print0 | xargs -0 du -h | sort -nr

616M     ./opt/backend/charge-service/1.2/shared/console.log
518M     ./data/log/charge-service/test-access.log.2016-08-08.log
357M     ./home/deploy/logs/testmqlogs/otherdays/testmq_client.2.log
301M     ./opt/backend/express_service/0.0.3.tar.gz
243M     ./home/deploy/logs/testmqlogs/otherdays/testmq_client.1.log
216M     ./data/log/aaa_service/test-access.log.2016-08-09.log
201M     ./opt/backend/aaa-service/1.2/shared/console.log



不过如上截图所示,有时候排列的顺序并不完全是按大小一致,这个是因为du命令的参数h所致,你可以统一使用使用MB来显示,这样就能解决这个问题。到这里,这个在Linux系统查找大文件的命令已经非常完美了,当然如果你还有很多的需求,那么可以在这个命令上做修改、调整.

2: 如何查找Linux下的大目录
譬如有时候磁盘空间告警了,而你平时又疏于管理、监控文件的增长,那么我需要快速的了解哪些目录变得比较大,那么此时我们可以借助du命令来帮我们解决这个问题。
1
2
3
4
5
6
7
[iyunv@getlnx01 u03]# du -h --max-depth=1
16K     ./lost+found
33G     ./flash_recovery_area
37G     ./oradata
70G     .

如果你想知道flash_recovery_area目录下面有哪些大文件夹,那么可以将参数max-depth=2 ,如果你想对搜索出来的结果进行排序,那么可以借助于sort命令。如下所示



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
[iyunv@getlnx01 u03]# du -h --max-depth=2 | sort -n
3.5G    ./flash_recovery_area/EPPS
16K     ./lost+found
29G     ./flash_recovery_area/backup
33G     ./flash_recovery_area
37G     ./oradata
37G     ./oradata/epps
70G     .
[iyunv@getlnx01 u03]# du -hm --max-depth=2 | sort -n
1       ./lost+found
3527    ./flash_recovery_area/EPPS
29544   ./flash_recovery_area/backup
33070   ./flash_recovery_area
37705   ./oradata
37705   ./oradata/epps
70775   .



有时候搜索出来的结果太多了(譬如,我从根目录开始搜索),一直在刷屏,如果我只想查出最大的12个文件夹,怎么办呢?此时就要借助head命令来显示了
1
2
3
4
5
6
7
8
9
10
11
12
13
[iyunv@getlnx01 /]# du -hm --max-depth=2 | sort -nr | head -12
407480  .
167880  ./u04
158685  ./u02/oradata
158685  ./u02
152118  ./u04/oradata
70775   ./u03
37705   ./u03/oradata
33070   ./u03/flash_recovery_area
5995    ./u01/app
5995    ./u01
3551    ./usr
1558    ./usr/share



参考资料:


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-265482-1-1.html 上篇帖子: [Linux] User and group management 下篇帖子: 部署P2P升级的脚本 Linux 如何
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表