文件的查找命令 find 和 locate

文件的查找命令 find 和 locate

find

功能:实时查找工具,通过遍历指定路径完成文件查找

工作特点:

•  查找速度略慢
•  精确查找
•  实时查找
•  可能只搜索用户具备读取和执行权限的目录

语法:

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

查找路径:指定具体目标路径;默认为当前目录
查找条件:指定的查找标准,可以文件名、大小、类型、权限等标准进行;默认为找出指定路径下的所有文件
处理动作:对符合条件的文件做操作,默认输出至屏幕

find 查找条件

根据文件名和inode查找:

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

  • *, ?, [], [^]

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

  • -inum n  按inode号查找

  • -samefile name  相同inode号的文件

  • -links n  链接数为n的文件

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

        find -name snow.png
      • 搜索名为snow.png的文件
        find -iname snow.png
      • 不分大小写地搜索名为snow.png、Snow.png、SNOW.PNG等等的文件
       find / -name “*.txt”  搜索后缀为.txt的文件
       find /var –name “*log*”

根据属主、属组查找:

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

  • -group GRPNAME: 查找属组为指定组(GID)的文件

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

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

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

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

       find -user joe  -group joe
       搜索被用户joe 以及组群joe所拥有的文件

根据文件类型查找:

-type TYPE:

•  f: 普通文件
•  d: 目录文件
•  l: 符号链接文件
•  s:套接字文件
•  b: 块设备文件
•  c: 字符设备文件
•  p: 管道文件

组合条件:

与:-a
或:-o
非:-not, !

德· 摩根定律:
(非 P) 或 (非 Q) = 非(P 且 Q)
(非 P) 且 (非 Q) = 非(P 或 Q)

 示例:
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)
找出/tmp目录下,属主不是root,且文件名不以f开头的文件
    find /tmp \( -not -user root -a -not -name 'f*' \) -ls
    find /tmp -not \( -user root -o -name 'f*' \)  –ls

根据文件大小来查找:

-size [+|-] #计算单位    

常用单位:b,c,w,k, M, G

  • 10k 表示(9k,10k]

  • -6k 表示[0,5k]

  • +8k 表示(8k,+∞)

根据时间戳:

以“天”为单位;

  • -atime [+|-]#,

    • #: [#,#+1)

    • +#: [#+1,∞]

    • -#: [0,#)

  • -mtime

  • -ctime

以“分钟”为单位:

  • -amin

  • -mmin

  • -cmin

      访问时间(-atime/天,-amin/分钟):用户最近一次访问时间。 
      修改时间(-mtime/天,-mmin/分钟):文件最后一次修改时间。 
      变化时间(-ctime/天,-cmin/分钟):文件数据元(例如权限等)最后一次修改时间。

根据权限查找:

-perm [/|-]MODE
MODE: 精确权限匹配

  • /MODE:任何一类(u,g,o)对象的权限中只要能一位匹配即可,或关系,+ 从centos7开始淘汰

  • -MODE:每一类对象都必须同时拥有指定权限,与关系

    •0 表示不关注

• find -perm 755 会匹配权限模式恰好是755的文件

• 只要当任意人有写权限时,find -perm +222就会匹配

• 只有当每个人都有写权限时,find -perm -222才会匹配

• 只有当其它人(other)有写权限时,find -perm -002才
会匹配

find 处理动作

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

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

  • -delete:删除查找到的文件;

  • -fls file:查找到的所有文件的长格式信息保存至指定文件中

  • -ok COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令;对于每个文件执行命令之前,都会交互式要求用户确认()

  • -exec COMMAND {} \;

    • 对查找到的每个文件执行由COMMAND指定的命令

注意:

{} \;    : 用于引用查找到的文件名称自身
find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题
find | xargs COMMAND

示例
 find  -name “*.conf”  -exec cp {} {}.org  \;
• 备份配置文件,添加.orig这个扩展名

 find /tmp -ctime +3 -user joe -ok rm {} \;
• 提示删除存在时间超过3天以上的joe的临时文件

 find ~ -perm -002  -exec chmod o-w {} \;
• 在你的主目录中寻找可被其它用户写入的文件,并去掉写权限

 find /data –type f -perm 644  -name “*.sh” –exec chmod 755 {} \;
 找出/date 权限为644的普通文件,并把他们改成755

 find /home –type d -ls
 找出/home 下的目录文件,并列出

关于 -exec和 xargs
该命令的主要功能是从输入中构建和执行shell命令。

 在使用find命令的-exec选项处理匹配到的文件时,   find命令将所有匹配到的文件一起传递给exec执行。但有些系统对能够传递给exec的命令长度有限制,这样在find命令运行几分钟之后,就会出现 溢出错误。错误信息通常是“参数列太长”或“参数列溢出”。这就是xargs命令的用处所在,特别是与find命令一起使用。  
find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它可以先处理最先获取的一部分文件,然后是下一批,并如此继续下去。  
在有些系统中,使用-exec选项会为处理每一个匹配到的文件而发起一个相应的进程,并非将匹配到的文件全部作为参数一次执行;这样在有些情况下就会出现进程过多,系统性能下降的问题,因而效率不高;  
而使用xargs命令则只有一个进程。另外,在使用xargs命令时,究竟是一次获取所有的参数,还是分批取得参数,以及每一次获取参数的数目都会根据该命令的选项及系统内核中相应的可调参数来确定。

find其他技巧

排除目录

• 示例:查找/etc/下,除/etc/sane.d目录的其它所有.conf后缀的文件
    find /etc -path ‘/etc/sane.d’ -a -prune -o -name “*.conf” -print

文件的查找命令 find 和 locate
注意:    -path  /root/bin -a  -prune  -o
      表示裁剪/root/bin 里面的内容  再搜索

要列出所有长度为零的文件

find . -type f -empty

[root@localhost ~]# find . -type f -empty -exec rm  {} \; 
[root@localhost ~]# find . -type f -empty

一点练习

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

[root@localhost ~]# find /var -user root -group mail
/var/spool/mail
/var/spool/mail/root

2、查找/var目录下不属于root、lp、gdm的所有文件

 find /var \( -not -user root -a -not -user lp -a -not -user gdm \)  -ls

3、查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

# find /var \( -mtime -7 -a -not -user root -a -not -user postfix \) -ls

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

find / \( -nouser -nogroup -atime -7 \) -ls

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

[root@localhost ~]# find /etc -size +1M -type f

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

# find /etc/ -not -perm /222 -ls

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

# find /etc/ -not -perm -111 -ls

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

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

locate

功能:查询系统上预建的文件索引数据库     /var/lib/mlocate/mlocate.db

  • 依赖于事先构建的索引

  • 索引的构建是在系统较为空闲时自动进行(周期性任务),管理员手动更新数据库(updatedb)

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

工作特点:

• 查找速度快
• 模糊查找
• 非实时查找
• 搜索的是文件的全路径,不仅仅是文件名
• 可能只搜索用户具备读取和执行权限的目录

语法: locate [选项] KEYWORD

有用的选项

  • • -i 执行区分大小写的搜索

  • • -n N 只列举前N个匹配项目

    • locate foo

  • • 搜索名称或路径中带有“foo”的文件

    • locate  -r ‘.foo$’

  • • 使用Regex来搜索以“.foo”结尾的文件

搜索etc目录下所有以sh开头的文件:

locate /etc/sh

搜索用户主目录下,所有以m开头的文件:

locate ~/m

搜索用户主目录下,所有以m开头的文件,并且忽略大小写:

locate -i ~/m

原创文章,作者:qzx,如若转载,请注明出处:http://www.178linux.com/36179

(0)
qzxqzx
上一篇 2016-08-16 13:59
下一篇 2016-08-16 13:59

相关推荐

  • case条件判断语句

    条件判断: case语句     在shell编程中,对于多分支判断,用if 虽然也可以实现,但有些时候,写起来很麻烦,也不容易代码理解。这个时候,可以考虑case。 case 变量引用 in PAT1) 分支1 ;; PAT2) 分支2 ;; … *) 默认分支 ;; esac case语句结构特点如下:…

    Linux干货 2016-08-16
  • 马哥教育网络班21期+第9周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash # declare -i nologuser=0 declare -i loguser=0 while read&…

    Linux干货 2016-09-05
  • Linux文件管理类命令相关

    Linux文件管理类命令相关 1、Linux上的文件管理类命令都有哪些,其常用的使用方法及其相关示例演示。 1)、查看文件命令: (1)ls命令: list,列出目录下的内容 语法: ls [OPTION]… [FILE]… 常用选项: -a: 显示所有文件,包括隐藏文件; -A:显示除.和..之外的所有文件; -l: –…

    Linux干货 2016-09-24
  • 生产环境日志审计

         日志审计,就是记录所有系统和相关用户行为的信息,并且可以自动分析,处理。在中小企业环境中,一般都是在单个服务器上记录日志,而大型企业的生产环境当中,会有专门的日志服务器乃至集群。本文通过sudo配合centos自带的rsyslog(syslog)服务,进行日志审计。    &nb…

    Linux干货 2016-10-20
  • 用户及用户组管理使用的练习

    用户及用户组管理使用的练习 1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 先使用who得出登陆用户,通过uniq去重。 [root@mail ~]# who | grep -E -o “^[[:alnum:]]+” | uniq root 2、取出最后登录到当前系统的用户的相关信息。 思路:首先使用who取得最后…

    Linux干货 2018-03-18
  • httpd2.2基础安装

    编译安装前,首先要确认开发包组已经装上。 开发包组: Developments tools server platform development(centos 7) 并且将apr 与 apr-unil 装上。这是httpd 可移植运行所必须用到的组件.这里举例说明的是httpd2.2版本。 若是安装httpd2.4以上版本的话,还要安装pcre库。pcre…

    2017-04-24

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-18 15:31

    总结的很好,很详细,排版精美,再接再厉。