Linux中find命令细节详解

Linux大全评论639 views阅读模式

find命令特点:文件查找,实时查找,速度略慢,精确匹配

使用格式:# find [options] [查找路径] [查找条件] [处理动作]

查找路径:默认为当前目录

查找条件:默认为查找指定路径下的所有文件

处理动作:默认为显示

  • 查找 /tmp 目录下文件名 passwd 的文件: # find /tmp -name "passwd"
  • 查找 /tmp 目录下文件名 passwd 开头的文件, passwd 不区分大小写 # find /tmp -iname "passwd*"
  • 查找 /tmp 目录下属主 keyso 的文件: # find /tmp -user keyso
  • 查找 /tmp 目录下属组 keyso 的文件: # find /tmp -group keyso
  • 查找 /tmp 目录下 UID 502 的文件: # find /tmp -uid 502
  • 查找 /tmp 目录下 GID 502 的文件: # find /tmp -gid 502

一个普通用户例如keyso创建了/tmp/keyso.txt,该文件属主和属组都是keyso,但当keyso用户被删除之后,/tmp/keyso.txt文件的属主和属组会发生变化,此种情况无法再根据属主为keyso这个被删除用户查找到/tmp/keyso.txt文件

  • 查找 /tmp 目录下没有属主的文件: # find /tmp -nouser
  • 查找 /tmp 目录下没有属组的文件: # find /tmp -nogroup
  • 查找 /tmp 目录下的目录: # find /tmp -type d

-type文件类型包括:f(普通文件)、d(目录)、b(块设备)、c(字符设备)、l(符号链接文件)、p(命名管道)和s(套接字)等

  • 查找/tmp目录下大于100M的文件:# find /tmp -size +100M

-size:根据文件大小查找,-size [+ | -]#[k | M | G]+(大于),-(小于),没有+-,就是精确匹配

#实际的取值范围:(#-1<x<=#

  • 查找/tmp目录下一天之内被访问过的文件:# find /tmp -atime -1

格式:-[a | m | c][time | min] [+ | -]#

根据time时间戳查找(以天为单位):

-atime:访问时间,就是一个文件最后一次被访问的时间

-mtime:修改时间,就是文件的内容最后被修改的时间

-ctime:改变时间,就是文件或者目录的属性(属主、属组、权限等等)被改变的时间

根据min时间戳查找(以分钟为单位):

-amin:意义同-atime

-mmin:意义同-mtime

-cmin:意义同-ctime

+#:表示(#+1)天之外被访问过

-#:表示#天之内被访问过

#:表示在#<=x<#+1)天的时间段内被访问过

  • 查找/tmp目录下权限为644的文件:# find /tmp -perm 644

根据权限查找,格式:-perm [+ | -]MODE

+MODE:任何一类用户的任何一位权限匹配,常用于查找某类用户的某特定权限是否存在

-MODE:每类用户的指定要检查的权限位都要匹配

MODE:精确匹配所给的权限

示例:        //6=4+2=r+w

  • 查找 /tmp 目录下权限为 666 的文件(精确匹配): # find /tmp -perm 666
  • 查找 /tmp 目录下其他用户有读写权限的文件: # find /tmp -perm -006
  • 查找 /tmp 目录下其他用户有读或者写权限的文件: # find /tmp -perm +006
  • 查找 /tmp 目录下至少有一类用户有写权限的文件: # find /tmp -perm +222
  • 查找 /tmp 目录下所有用户都有写权限的文件: # find /tmp -perm -222
  • 查找 /tmp 目录下所有用户都没有写权限的文件: # find /tmp -not -perm +222

       //“所有用户都没有”和“只要有一类用户有”意思相反

       //只确定不能有写权限,并不能确定有没有读和执行权限

  • 查找/tmp目录下至少有一类用户没有写权限的文件:# find /tmp -not -perm -222

       //“至少有一类用户没有”和“所有用户都有”意思相反

  • 查找 /tmp 目录下属组或者其他用户有读写权限的文件: # find /tmp -perm -060 -o -perm -006
  • 查找 /tmp 目录下属组和其他用户都有读写权限的文件: # find /tmp -perm -066
  • 查找 /tmp 目录下属组有读或者写权限,或者其他用户有读或者写权限的文件( 4 1 ):

# find /tmp -perm +066

  • 查找 /tmp 目录下的普通文件,并删除: # find /tmp -type f -exec rm -rf {} \;
  • 查找 /tmp 目录下大于 10M 的文件,并以长格式显示文件信息: # find /tmp -size +10M -ls
  • 查找 /tmp 目录下以 .doc 结尾的文件,并重命名为 .docx # find /tmp -iname "*.doc" -exec mv {} {}x \;

处理动作:

-ls:以长格式显示文件信息

-exec COMMAND {} \; -->  对查找到的文件执行指定的命令,{}为占位符,指代find查找到的文件

-ok COMMAND {} \; -->  -exec COMMAND {} \;类似,交互式的-exec

|xargs COMMAND:对查找到的文件执行指定的命令,功能与-exec COMMAND {} \;类似

备注:-execxargs的区别

-execfind将查找到的所有文件一次性全部传递给-exec所指定的命令,容易出现溢出错误。-exec为处理每一个匹配到的文件而发起一个相应的进程,会导致进程过多,系统性能下降

xargs:对find传递给xargs所指定的命令的文件,每次只获取一部分而不是全部,不会出现溢出错误。另外xargs只会发起一个进程,不会导致系统性能下降

  • 查找/tmp目录下没有属主或属组,且最近1个月内曾被访问过的文件:

# find /tmp \( -nouser -o -nogroup \) -a -atime -30            //括号内侧的两端都需要加空格

组合条件:

-a:与,同时满足,如果组合条件中只有-a,可以省略  -->  # find /tmp -user Hadoop [-a] -name "*.txt"

-o:或,只需满足其一即可,优先级比-a低,如果需要先执行-o条件,需要加()()需要转义

-not | !:非,取反

A且非B  <==>  非(AB      -not A -a -not B  <==> -not \( A -o B \)

企鹅博客
  • 本文由 发表于 2020年8月11日 08:26:10
  • 转载请务必保留本文链接:https://www.qieseo.com/239074.html

发表评论