文件查找

目录

一、相关命令

二、locate

三、find

1.查找条件

2.处理动作

练习

参考资料

在文件系统上查找符合条件的文件

一、相关命令

      文件查找:locate, find

            非实时查找(数据库查找):locate

            实时查找:find

二、locate

      依赖于事先构建的索引;索引的构建是在系统较为空闲时自动进行(周期性任务);手动更新数据库(updatedb)

索引构建过程需要遍历整个根文件系统,极消耗资源

      工作特点

                  查找速度快

                  模糊查找

                  非实时查找

      用法

            locate KEYWORD

三、find

      实时查找工具,通过遍历指定路径下的文件系统完成文件查找

      工作特点

                  查找速度略慢

                  精确查找

                  实时查找

      语法

            find [OPTION]... [查找路径] [查找条件] [处理动作]

                  查找路径:指定具体目标路径;默认为当前目录

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

                  处理动作:对符合条件的文件做什么操作;默认输出至屏幕

1.查找条件

①根据文件名查找:-name

            -name "文件名称":支持使用glob

                                         *, ?, [], [^]

            -iname "文件名称":不区分字母大小写

-regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称

②根据属主、属组查找:-user, group, uid, gid, nouser, nogroup

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

            -group GRPNAME:查找属组为指定组的文件

            -uid UserID:查找属主为指定的UID号的文件

            -gid GroupID:查找属组为指定的GID号的文件

 

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

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

③根据文件类型查找:-type

            -type TYPE:

                  f:普通文件

                  d:目录文件

                  l:符号链接文件

                  s:套接字文件

                  b:块设备文件

                  c:字符设备文件

                  p:管道文件

组合条件:

            与:-a

            或:-o

            非:-not, !

            !A  -a  !B = ! (A  -o  B)

            !A  -o  !B = ! (A  -a  B)

      找出/tmp目录下,属主不是root,且文件名不是fstab的文件

                  find /tmp \( -not -user root -a -not -name 'fstab' \) -ls                                find /tmp -not \( -user root -o -name 'fstab' \) -ls

文件/tmp/fin/issue,passwd也没有属组,-nogroup -ls为什么没有展示它们?

与动作的位置有关(纯粹看成短路运算可能不太精确),-nouser评估结果为真,不会对它们评估-nogroup,所以不会执行-ls这个动作

④根据文件大小查找:-size

            -size [+|-]#UNIT           常用单位UNIT:k, M, G

                       #:(#-1, #]

                       -#:[0,#-1]

                       +#:(#,oo)

⑤根据时间戳查找:-xtime, xmin

            以“天”为单位:

                  -atime [+|-]#, 

                       #:[#,#+1)

                       +#:[#+1,oo]

                       -#:[0,#)

                  -mtime

                  -ctime

            以“分钟”为单位:

                  -amin

                  -mmin

                  -cmin

⑥根据权限查找::-perm

            -perm [/|-]MODE

                        MODE:精确权限匹配

                        +MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可

                       -MODE:每一类对象都必须同时拥有为其指定的权限标准、

                                   e.g. -666    766 符合标准 760 不合标准

2.处理动作

      -print:默认的处理动作,显示至屏幕

      -ls:类似于对查找到的文件执行“ls -l”命令

      -delete:删除查找到的文件

      -fls /path/to/somefile:查找到的所有文件的长格式信息保存至指定文件中

      -ok COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令

                                   对于每个文件执行命令之前,都会交互式要求用户确认

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

                                   {}:用于引用查找到的文件名称自身

注意:find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令

有些命令不能接受过多参数,此时命令执行可能会失败;另一种方式可规避此问题:

                                   find | xargs COMMAND

练习

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

                  # find /var -user root -group mail

                  #find /var \( -user root -a -group mail \) -ls

  • 查找/usr目录下不属于root、bin或hadoop的所有文件或目录

                  # find /usr -not -user root -a -not -user bin -a -not -user hadoop

                  # find /usr ! \( -user root -o -user bin -o -user hadoop \)

  • 查找/etc目录下最周一周内其内容修改过,同时属主不为root,也不是hadoop的文件或目录

                  # find /etc -mtime -7 -a -not -user root -a -not -user hadoop

                  # find /etc/ -mtime -7 -a -not \( -user root -o -user hadoop \)

  • 查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件或目录

                  # find / -nouser -a -nogroup -a -atime -7

                  # find / -not \( -nouser -o -nogroup \) -a -atime 7

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

                  # find /etc -size +1M -type f

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

                  # find /etc -not -perm /222

  • 查找/etc目录下至少有一类用户没有执行权限的文件

                  # find /etc -not -perm -111

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

                  # find /etc/init.d -perm -113

      小结:⑥-⑧这类问题结合权限查找中各权限间的逻辑关系(与、或、非)切入

      没有A或Bónot ( A -o B )ó既不是A,也不是Bó-not A -a -not B

      CentOS 7 的 -prem 后的 + 换成了 /

参考资料:

马哥随堂笔记

注:诚恳欢迎读者对本文提出批评意见,若发现存在错误,我定第一时间修改。如果读者觉得文章对您有帮助,欢迎点赞鼓励一下哟٩(๑❛ᴗ❛๑)۶。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值