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

相关推荐

  • Linux进程管理命令和性能监控工具的应用

    概述 监控系统的各方面的性能,保障各类服务的有序运行,是运维工作的重要组成部分,本篇就介绍了一些常用的系统监控命令和相关参数的说明 具体包含一下几个部分 1.进程管理基础 2.进程管理工具(ps,top,htop,kill) 3.内存监控类工具(vmstat,pmap) 4.系统监控累工具(glances,dstat)…

    Linux干货 2016-09-26
  • 说说linux权限管理(1)

    在这篇文章当中你可以看到: 1、linux系统文件普通权限 2、文件所属主的设置,组的指定 3、特殊权限 4、acl权限 5、su命令及其注意事项和sudo权限 6、权限管理的注意点 0、首先,在linux下用户账户是分角色的,由于角色的不同,每个角色,每个用户的的权限和所能完成的任务也不同。而在实际管理中,用户的角色是通过UID(用户id号)来标识的,每个…

    Linux干货 2016-04-30
  • linux一周学习总结

          对于linux,之前也完全没有接触过,完全零基础小白。来到马哥以后,进入学习也有一周时间 ,一周里老师带我们学习了很多指令,下面,我就自己的理解和老师讲授的内容对linux中的一些指令做一个简单的小总结。 一、关于SHELL Shell     查询当前系统使用了哪个shell   &n…

    2017-07-15
  • 文件的权限、扩展属性以及facl

    大纲: 一、前言 二、普通权限 三、特殊权限 四、ext文件的扩展属性 五、文件的访问控制列表(facl) 一、前言 linux中常见的权限有读(r)、写(w)、执行(x),还有3个特殊的权限。因此下面就从普通权限开始介绍起 二、普通权限 rwx:读 写 执行 rwxr-xr-x : 读写执行 读_执行 读_执行  (分别对应)属主 属组…

    Linux干货 2015-05-04
  • sed

    sed Stream EDitor, 行编辑器 sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非使用重定向存储输出。 Sed主要用来自动…

    Linux干货 2017-04-26
  • 先给出自动化编译安装httpd的脚本,后面的mysql,php-fpm,xcache等还在测试中

    自动化编译安装httpd的脚本! FUNDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" echo "Make …

    Linux干货 2016-10-30