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

相关推荐

  • LVM2:创建、使用、扩展、缩减、快照五步骤

    LVM2这是个关键的概念,还是从操作中比较容易理解 1、创建一个至少有两个PV组成的大小为40G的名为testvg的VG;要求PE大小为16MB, 而后在卷组中创建大小为5G的逻辑卷testlv;挂载至/users目录 注意点:在vmware中添加两块硬盘,但是并不能马上可以查看,需要扫描一下磁盘,磁盘未/dev/sdc,/dev/sdd 然后创建LVM的基…

    Linux干货 2016-09-05
  • N22-第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。      2、编辑/etc/group文件,添加组hadoop。 3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为…

    Linux干货 2016-09-05
  • 第九周-Shell脚本编程

      1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash nologin=0 login=0 for i in `cut -d : -f 7 /etc/passwd`;do if [ $i = /sbin/n…

    Linux干货 2017-08-23
  • 采用二进制包安装mysql

    本文是在CentOS7系统平台下安装Mysql5.6.26版本数据库的操作说明,如有错误,请指正。 系统平台:CentOS-7-x86_64    数据库版本:mysql-5.6.26   Mysql镜像文件下载地址:http://dev.mysql.com/downloads/mirrors.html 本次演示的Mysql安装…

    Linux干货 2017-05-04
  • 6 文件系统权限(一):用户、组

    提纲 文件系统权限 3A 安全 Authentication    :  认证    –> 用户名&密码、指纹、人脸识别、DNA验证 Authorization    :  …

    Linux干货 2016-08-10
  • 设计模式(二)单件模式Singleton(创建型)

      几乎所有面向对象的程序中,总有一些类的对象需要是唯一的,例如,通过数据库句柄到数据库的连接是独占的。您希望在应用程序中共享数据库句柄,因为在保持连接打开或关闭时,它是一种开销。再如大家最经常用的IM,如QQ,在同一台电脑,一个帐号只能有唯一的登录。 1. 问题 怎样确保一个特殊类的实例是独一无二的(它是这个类的唯一实例),并且这个实例…

    Linux干货 2015-06-24