Linux文件查找

什么是文件查找
    在文件系统中查找符合条件的文件;
文件查找分为:
    实时查找:遍历所有文件进行条件匹配(find)
    非实时查找:根据索引查找(locate)
locate
 查询系统上预建的文件索引数据库
        /var/lib/mlocate/mlocate.db
 依赖于事先构建的索引;
        索引的构建是在系统较为空闲时自动进行(周期性任务);管理员手动更新数据库(updatedb);
 索引构建过程需要遍历整个根文件系统,极消耗资源;
 工作特点:
    查找速度快;
    模糊查找;
    非实时查找
    搜索的是文件的全路径,不仅仅是文件名
    可能只搜索用户具备读取和执行权限的目录

locate命令
 有用的选项
    -i 执行区分大小写的搜索
    -n X 只列举前X个匹配项目
 locate foo
    搜索名称或路径中带有“ foo”的文件
 locate -r ‘\.foo$’
    使用Regex来搜索以“ .foo”结尾的文件
find
    实时查找工具,通过遍历指定路径完成文件查找;
    工作特点:
        查找速度略慢
        精确查找
        实时查找
        可能只搜索用户具备读取和执行权限的目录
find命令
    语法:
 find [OPTION]... [查找路径] [查找条件] [处理动作]
    查找路径:指定具体目标路径;默认为当前目录
    查找条件:指定的查找标准,可以文件名、大小、类型、
    权限等标准进行;默认为找出指定路径下的所有文件
    处理动作:对符合条件的文件做操作,默认输出至屏幕
查找条件
根据文件名和inode查找:
    -name "文件名称":支持使用glob
    *, ?, [], [^]
    -iname "文件名称":不区分字母大小写
    -inum n 按inode号查找
    -samefile name 相同inode号的文件
    -links n 链接数为n的文件
    -regex "PATTERN":以PATTERN匹配整个文件路径字符串,而不仅仅是文件名称
根据属主、属组查找:
    -user USERNAME:查找属主为指定用户(UID)的文件
    -group GRPNAME: 查找属组为指定组(GID)的文件
    -uid UserID:查找属主为指定的UID号的文件
    -gid GroupID:查找属组为指定的GID号的文件
    -nouser:查找没有属主的文件
    -nogroup:查找没有属组的文件
根据文件类型查找:
    -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)
根据文件大小来查找:
    -size [+|-]#UNIT
    常用单位: k, M, G
    #UNIT: (#-1, #],如: 6k
    -#UNIT: [0,#-1], 如: -6k
    +#UNIT: (#,∞), 如: +6k
根据时间戳:
以“天”为单位;
    -atime [+|-]#,
    #: [#,#+1)
    +#: [#+1,∞]
    -#: [0,#)
    -mtime
    -ctime
以“分钟”为单位:
    -amin
    -mmin
    -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才会匹配
处理动作
     -print:默认的处理动作,显示至屏幕;
   -ls:类似于对查找到的文件执行“ ls -l”命令
   -delete:删除查找到的文件;
   -fls file:查找到的所有文件的长格式信息保存至指定文件中
   -ok COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令;
        对于每个文件执行命令之前,都会交互式要求用户确认
-exec COMMAND {} \; 对查找到的每个文件执行由COMMAND指定的命令
 {}: 用于引用查找到的文件名称自身
 find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
 有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题
        find | xargs COMMAND

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

(0)
RecallWzcRecallWzc
上一篇 2016-08-14
下一篇 2016-08-15

相关推荐

  • 搭建lnmp实现动静分离

    LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。 (nginx主机)web 处理静态内容 172.16.250.149 (fpm server   mariad bserver)处理动态内容 172.16.253.131 以上为两台CentOS7.3主机 试验拓扑图如下:   ==…

    2017-07-22
  • Linux基础知识点(一)

    此篇博客只是记录第一周未掌握或不熟悉的知识点,用来加深印象。

    2018-03-13
  • N25-第10周博客作业

    请详细描述CentOS的启动流程     启动第一步–加载BIOS         当打开计算机电源,计算机会首先加载BIOS信息,BIOS信息是如此的重要,以至于计算机必须在最开始就找到它,这是因为BIOS中包含了CPU的相关信息、设备启动顺序信息、硬盘信息、内存信息…

    Linux干货 2017-03-10
  • 网络管理、进程管理、计划任务及启动流程

          网络管理 一.网卡模块操作步骤: 查询网卡模块类型:ethtool  -i  eth1 查询网卡模块lsmod |grep e1000 删除网卡模块rmmod e1000  或者modprobe  -r  e1000 添加网卡模块 modprobe e1000 删除模…

    Linux干货 2016-09-08
  • week3:cut,sort,grep等shell工具的应用及用户,组管理类命令

    1、列出当前系统上所有已经登录的用户的用户名,注意,同一个用户登录多次只显示一次即可    who | cut -d' ' -f1 | sort –u 2、取出最后登录到当前系统的用户相关信息    who | cut -d' ' -f1 | tail -1 | id 3、取出当…

    Linux干货 2016-11-20
  • 文件权限

     本篇博客是对文件权限的简单介绍,将会简述下权限的数字表现形式,还有字母表现形式,还有一些特殊的suid、sgid、sticky的权限介绍,还有对ACL权限的简述。  一、权限的定义     关于权限,百度百科的解释如下:权限(privilege)是指某个特定的用户具有特定的系统资源使用权力,像是文…

    Linux干货 2017-07-29