find

 finds是实时查找工具,遍历指定起始路径下文件系统层级结构完成文件查找


一、工作特性:

        1、查找速度较慢

        2、精确查找

        3、实时查找

 find [OPTIONS][查找起始路径][查找条件][处理动作]

       查找起始路径:指定具体搜索目标起始路径,默认为当前目录

       查找条件:指定的查找标准,可以根据文件名、大小、类型、从属关系权限等等               标准进行,默认为找出指定路径下的所有文件

       处理动作:对符号查找条件的文件做出的操作,例如删除等操作,默认为输出至               标准输出


二、查找条件:

        

1、根据文件名查找:

             -name "pattern"

             -iname "pattern"匹配时忽略大小写

             支持glob风格的通配符

              *,?,[],[^]

              -regex pattern :基于正则表达式模式查找文件,匹配是整个路径,                          而非其名

2、根据文件从属关系查找:

              -user USERNAME:查找属主指定用户的所有文件

              -group USERNAME:查找属组指定组的所有文件

              -uid UID:查找属主指定的UID的所有文件

              gid UID:查找属组指定的GID的所有文件

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

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

  例:

  1.查找/var目录下属主为root,且属组为gentoo的所有文件或目录

     ~]# find /var -user root -a -gentoo user -ls

find详解_find

3、根据文件的类型查找:

              -type TYPE

              f:普通文件

              d:目录文件

              l:符号链接文件

              b:块设备文件

              c:字符设备文件

              p:管道文件

                  s:套接字文件

4、组合测试:

             与:-a,默认组合逻辑

             或: -o,二个符合一即可

             非:-not,取反

  例:  

  1.查找/tmp目录下不属于root, bin或user1的所有文件或目录;用两种方法;

     ~]# find /tmp -not -user root -a -not -user bin -a -not -user user1

     ~]# find /tmp -not \( -user root -o -user bin -o -user user1 \) -ls

find详解_find_02

5、据文件的大小查找:

   -size [+|-]#UNIT

   常用单位:k, M, G

   #UNIT:(#-1, #]

   -#UNIT:[0,#-1]

   +#UNIT:(#, oo)

  例:

  1.查找/etc目录下大于2M且类型为普通文件的所有文件;

    ~]# find /etc -size +2M -type f -exec ls -lh {} \;

find详解_find_03

6、根据时间戳查找:

 (1)以“天”为单位

   -atime [+|-]#

    #: #= < x < #+1

   -#: x < #

   +#: x >= #+1

   -mtime [+|-]#

   -ctime [+|-]#


 (2)以“分钟”为单位

   -amin [+|-]#

   -mmin

   -cmin

  例:

  1.查找/tmp目录下最近一周内其内容修改过,且属主不是root用户也不是hadoop用户的文    件或目录;

   ~]# find /tmp -mtime -7 -a -not \( -user root -o -user hadoop \) -ls

find详解_find_04

7、根据权限查找:

  (1) -perm [/|-]MODE

   MODE: 与MODE精确匹配

  /MODE:任何一类用户的权限只要能包含对其指定的任何一位权限即可;

  -MODE:每一类用户的权限都包含对其指定的所有权限;

  例:

  1.查找/etc/init.d/目录下,所有用户都有执行权限,且其它用户有写权限的所有文件;

   ~]# find /etc -perm -113 -type f -ls

  2.查找/etc目录下所有用户都没有写权限的文件;

   ~]# find /etc -not -perm /222 -type f -ls

  (2)处理动作:

   -print:默认至标准输出;默认的动作

   -ls:类似于对查找到的文件执行ls -l命令,输出文件的详细信息

   -delete:删除查找到的文件

   -fls /PATH/TO/SOMEFILE:查找到的所有文件的长格式信息保存至指定文件中

   -ok COMMAND{}\; :对查找到的每个文件执行由COMMAND表示的命令,每次操作都由用户                进行确认

   -exec COMMAND {}\; :对查找到的每个文件执行由COMMAND表示的命令

 例:

  1.查找/etc目录下大于1M且类型为普通文件的所有文件;

   ~]# find /etc -size +1M -type f -exec ls -lh {} \;

注意:find传递查找到的文件路径至后面的命令时,是先查找出所有符合条件的文件路径,并    一次性传递给后面的命令;但是有些命令不能接受过长的参数,此时命令执行会失败,    另一种方式可规避此问题