博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Linux的文件搜索神器-find
阅读量:6915 次
发布时间:2019-06-27

本文共 1889 字,大约阅读时间需要 6 分钟。

一、前言

我们在使用Linux的时候,难免会用到文件搜索,即想找到某配置文件的位置,某种类型的文件在特定目录下的数量,或者统一对具有某种权限的文件进行权限修改等,而这时候就需要用到Linux下强大的find命令。当然locate也可以定位某些文件,但功能就逊色很多了,下面会先对findlocate的异同进行分析的。

二、locatefind对比

locate

  1. 依赖于数据库(由系统计划任务自动生成)

  2. 非实时查询,结果非精确,即模糊查找

  3. 查找速度快

  4. 手动生成数据库的命令:updatedb(不适用于生产环境)

find

  1. 实时查找,速度慢

  2. 精确匹配查找

三、find的命令格式

1
find 
[options] [查找路径] [查找条件] [处理动作]
  1. 若直接执行find命令,则会打印出当前目录下的所有文件;

  2. find命令的默认值图解如下:

四、find查找条件

  1. -name “文件名称:精确查找文件名,支持使用globbing(*,?,[],[^])

  2. -iname “文件名称:查找时不区分大小写

  3. -user UserName:根据属主查找

  4. -group GroupName:根据属组查找

  5. -uid UID:根据UID查找

  6. -gid GID:根据GID查找

  7. -nouser:查找没有属主的文件

  8. -nogroup:查找没有属组的文件

  9. -type:根据文件类型查找(f,d,b,c,p,s)

  10. -size [+|-]#Unit:根据文件大小查找常用单位KMG

    1. 时间的独特点,图解如下

    2. find /tmp -size -1M表示大小为0的文件

  11. 根据时间戳查找(不存在未来时)

    1. 以天为单位(time)

      1. -atime [+|-]#:访问时间

      2. -mtime :修改时间

      3. -ctime :改变时间

    2. 以分钟为单位(min)

      1. -amin [+|-]#:访问时间

      2. -mmin:修改时间

      3. -cmin:改变时间

    3. 时间的划分图解如下:

  12. -perm [+|-]MODE:根据权限查找

    1. MODE:精确匹配

    2. +MODE:任何一类用户的任何一位权限匹配即可;常用于查找某类用户的某特定权限是否存在[宽泛匹配]

    3. -MODE:三类用户的指定要查找的权限位都匹配[严格匹配]

    4. 实例图解如下

五、组合条件查找

  1. -a:与,同时满足,默认值,可不写

  2. -o:或,两条件满足其一即可

  3. -not!:非,取反

1
2
find 
/tmp 
-not -user hadoop -not -name “*.txt”
find 
/tmp 
-not \(-user hadoop -o -name “*.txt”\)

六、find处理动作

  1. -print:打印在标准输出上

  2. -ls:以长格式输出各文件信息

  3. -exec COMMAND {} \;:对查找的文件执行执行的命令

  4. -ok COMMAND {} \;交互式-exec,对每个文件询问是否执行命令

  5. execxargs的区别:

    1. find把查找到的文件一次性传递给-exec所指定的命令;而有些系统对能够传递给exec的命令长度有限制,则会报错参数列太长参数列溢出

    2. xargs可以分批次传递find搜索到的文件,find | xargs 若对查找到的文件需连续引用2次时,则只能使用-exec,如

      1
      find 
      /tmp 
      -iname “*.doc” -
      exec 
      mv 
      {} {}x \;

七、实例

1
2
3
4
5
6
7
8
9
10
#查找/etc/目录下最近一周内其内容修改过的,且不属于root或hadoop的文件;
find 
/etc/ 
-mtime -7 -a -not \( -user root -o -user hadoop \)
#查找当前系统上没有属主或属组,且最近1个月内曾被访问过的文件;
find 
/ \( -nouser -o -nogroup \) -a -atime -30
#查找/etc/目录下大于1M且类型为普通文件的所有文件;
find 
/etc/ 
-size +1M -a -
type 
f
#查找/etc/目录所有用户都没有写权限的文件;
find 
/etc/ 
-not -perm +222
#查找/etc/init.d/目录下,所有用户都有执行权限且其它用户有写权限的文件;
find 
/etc/init
.d/  -perm -113
本文转自 xxrenzhe11 51CTO博客,原文链接:http://blog.51cto.com/xxrenzhe/1363524,如需转载请自行联系原作者
你可能感兴趣的文章
java--xml文件读取(DOM)
查看>>
Bootstrap-表单
查看>>
hiveserver2连接报错: User: root is not allowed to impersonate anonymous (state=08S01,code=0)
查看>>
android:使用Messenger进行进程间通信(一)
查看>>
HDU(1016),打素数环
查看>>
2007 Asia - Nanjing F题,字典树
查看>>
Codeforces 758D Ability To Convert(区间DP)
查看>>
Gym 100090D Insomnia
查看>>
完全隐藏Master Page左边导航条只有管理员才可以看见
查看>>
微信支付详解
查看>>
ubuntu install GTK-GNOME development environment
查看>>
为iDempiere 1.0b安装中文语言包(基于Ubuntu Desktop 12.04 LTS)
查看>>
React之JSX语法
查看>>
并行逻辑回归
查看>>
Graphviz样例之UML图
查看>>
XmlBeanFactory
查看>>
《Linux内核设计与实现》读书笔记(二)- 内核开发的准备
查看>>
开源MongoDB管理工具MongoCola1.20 发布 离开IBM GDC的最后一个版本
查看>>
03C++语言对C的增强——实用性、变量检测、struct类型、C++中所有变量和函数都必须有类型、bool类型、三目运算符...
查看>>
LVM逻辑卷
查看>>