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-15 09:21
下一篇 2016-08-15 09:21

相关推荐

  • 马哥教育网络班21期+第一周课程练习

    一、计算机的组成及其功能 自上个世纪40年代开始截止到目前,我们所有的计算机包括手持的智能终端设备,它们整个组织体系设备都是遵循冯诺依曼体系结构。 现代计算机设备的组成部分: 运算器、控制器、存储器、输入设备、输出设备 控制器:控制器是整个计算机的枢纽,一般是控制计算机整个部件之间协调的,比如运算器要想运算的话,首先得从存储器中取出数值。或者输入设备输入数。…

    Linux干货 2016-07-07
  • 推荐-运维学习笔记-Puppet应用配置的工作原理

    背景知识 Puppet的核心功能是配置管理。一般来说,用户在master上集中做配置,同时,被管理节点上的agent会定期从master上下载配置数据,再应用(apply)到本地,从而使管理节点的状态(用户,组,文件,安装包,服务等的设置和运行状态)与masters上定义的保持一致。 有时,出于测试的目的,并不希望真的应用配置,那么就需要执行puppet a…

    2016-06-01
  • 进程,自动化任务与安全

    进程     进程就是一段存储了一个指令集的内存空间    相关命令:        pstree:显示当前运行的进程树,按树状结构显示     &n…

    Linux干货 2017-04-02
  • Linux磁盘、文件系统管理

    对Linux而言,其哲学思想之一就是一切皆文件,因此Linux之上所有设备的操作都是通过文件接口来实现的,也就是说在访问设备的时候就如同访问一个文件一样,因为他们使用的都是文件系统接口。  设备也分种类,如:     1、块设备:block 其存取单位是“块”,如硬盘    &n…

    Linux干货 2016-08-29
  • 第10周作业(下)

    4、写一个脚本(1) 能接受四个参数:start, stop, restart, statusstart: 输出“starting 脚本名 finished.”(2) 其它任意参数,均报错退出。 #!/bin/bash # [ $# -ne 1 ] && echo &quo…

    Linux干货 2017-01-03
  • iptables

    iptables简介   iptables 是与最新的 3.5 版本 Linux 内核集成的 IP 信息包过滤系统。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器, 则该系统有利于在 Linux 系统上更好地控制 IP 信息包过滤和防火墙配置。 iptables基础   规则(rules)其实就是网络管理员预定义的条…

    Linux干货 2017-02-16