linux上的文件查找工具:locate和find

一、非实时超找工具 locate

    1、locate是查询系统上预建的文件索引数据库/var/lib/mlocate/mlocate.db文件索引实在系统比较空闲的时候自动进行的,是系统的周期性任务,因为是周期性任务,所以有些短期的数据无法更新到数据库,如果需要马上应用,乣管理员手动更新数据库,用命令updatedb来执行。同时索引的构建过程是遍历整个根文件系统,所以非常消耗系统资源,最好是在系统空闲时间进行更新。

    2、locate超找的特点:

    (1)查找速度快。因为是查找预先建立起来的索引数据库,不需要查找整个文件系统,所以速度快速

    (2)模糊超找

    (3)非实时超找

    (4)搜索的文件是全路径,不仅仅是文件名

    (5)只能搜索用户具备读取和执行权限的目录

    3、locate命令的用法

    locate [OPTION] KEYWORD

    常用选项

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

    -n X    只列举前X个匹配项目

    -r    支持正则表达式

二、实时超找工具find

   1、find是实时超找工具,查找时通过遍历指定路径完成文件的超找

   2、工作特点

    (1)查找速度略慢

    (2)能够时间精确查找

    (3)实时查找

    (4)只能搜索用户具备读取和执行权限的目录

   3、语法

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

  [查找路径]:

    可以使用-path选项,来使用通配符匹配路径

    指定具体目标路径,默认为当前工作目录,  .指定当前工作目录, ..指定父目录

  [查找条件]:

    指定的查找标准,可以是文件名、大小、类型、权限等标准进行;默认为找出路径下的所有文件

  [处理动作]:

    对符合条件的文件做操作,默认输出值屏幕

   4、查找条件

(1)根据文件名、inode查找和正则表达式查找

    -name “文件名称”,支持使用glob(通配符)* ? [] [^]等。-name总是用给定的文件名进行匹配,

-path则将文件路径作为一个整体进行匹配,例如

32.png

    -name "文件名称",不区分字母大小写

    -inum n      按inode号码超找

    -samefile name   相同inode号码超找

    -links n       链接数为n的文件

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

(2)根据属主、属组查找

-user USERNAME

    查找属主为指定用户(UID)的文件

-group GRPNAME 

    查找属组为指定组(GID)的文件

-uid UserID

    查找属主为指定的UID号的文件

-gid GroupID

    查找属组为指定的GID号的文件

-nouser

    查找没有属主的文件

-nogroup    

    查找没有属组的文件

(3)根据文件类型查找

-type TYPE

    f:普通文件

    d:目录文件

    l:符号链接文件

    s:套接字文件

    b:块设备文件

    c:字符设备文件

    p:管道文件

(4)根据文件大小来查找

-size [文件大小]

常用单位:k,m,G

其中文件大小分为三种情况,可以将[0,+∞)的数轴分为三段,假设a正整数数字,可以将数轴分为三段,[0,a-1]、(a-1,a]、(a,+∞),在搜索时第一段可以用 -a 表示,第二段用 a 表示,第三段用 +a 表示

(5)根据时间戳来查找

    以天为单位

  -atime [时间段] 

  -mtime [时间段]

  -ctime [时间段] 

 其中时间段的划分与根据文件大小的划分相同

以分钟为单位

  -amin   -mmin   -cmin 


(6)根据权限查找

   -perm [/|-]MODE

   MODE:精确权限匹配

   /MODE:任何一类(u、g、o)对象的权限中只能以为匹配即可,是或的关系

   -MODE:每一类对象都必须同时又有指定权限,与关系0表示不关注

(7)处理动作

-print

    默认的处理动作,显示至屏幕

-ls

    类似于对查找到的文件执行"ls -l"命令

-delete

    删除查找到的文件

-fls file

    查找到的所有文件的长格式信息保存至指定文件中

-ok COMMAND {}\

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

(8)基于目录深度的查找 -maxdepth和-mindepth

    find命令在使用时会遍历所有的子目录,我们可以使用-maxdepth和-mindepth选项来限制find命令遍历目录的深度。

    大多数情况下,我们只需要在当前目录下进行查找,无需继续往下查找。对于这用情况,我们使用深度选项来限制find命令向下查找的深度。如果只允许find在当前目录中查找,深度可以设置为1;当需要向下两级是,深度设置为2;其他情况以此类推。

    可以用-maxdepth指定最大深度,使用-mindepth指定最小深度

PS:-maxdepth和-mindepth应该作为find的第三个参数出项。如果作为第四个参数或者之后的参数,就可能影响find的效率,因为它不得不进行一些不必要的检查。例如,如果-maxdepth作为第四个参数,-type作为第三个参数,find首先会找出符合-type的所有文件,然后在所有匹配的文件中再找出符合指定深度的那些。但是如果倒过来,目录深度作为第三个参数,-type作为第四个参数,那么find就能够在找到的所有符合指定深度的文件后,再检查这些文件类型,这才是最有效的搜索之道



  

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

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

相关推荐

  • N28-第四周

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。
    2、编辑/etc/group文件,添加组hadoop。
    3、手动编辑/etc/passwd文件新增一行,添加用户hadoop,其基本组ID为hadoop组的id号;其家目录为/home/hadoop。
    4、复制/etc/skel目录为/home/hadoop,要求修改hadoop目录的属组和其它用户没有任何访问权限。
    5、修改/home/hadoop目录及其内部所有文件的属主为hadoop,属组为hadoop。
    6、显示/proc/meminfo文件中以大写或小写S开头的行;用两种方式;
    7、显示/etc/passwd文件中其默认shell为非/sbin/nologin的用户;
    8、显示/etc/passwd文件中其默认shell为/bin/bash的用户;
    9、找出/etc/passwd文件中的一位数或两位数;
    10、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;
    11、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;
    12、打出netstat -tan命令执行结果中以‘LISTEN’,后或跟空白字符结尾的行;
    13、添加用户bash, testbash, basher, nologin (此一个用户的shell为/sbin/nologin),而后找出当前系统上其用户名和默认shell相同的用户的信息;

    2017-12-30
  • linux文件管理

    目录创建删除,软硬链接的区别和注意,file命令的使用,工作中遇到一些情况的处理方法

    2017-11-18
  • Python第一周小结

    经历了两个星期Linux运维基础的铺垫,这周我们正式开始了python的学习。经过第一周的各种挣扎以及反复训练,终于有所收获了一点东西。现在将第一周中学到的一个非常重要的算法技巧总结如下: 即:折半思想 例:给定一个不超过五位数的正整数,判断该数有几位数 Code1:                                              …

    Linux干货 2018-03-26
  • 配额限制、RAID、LVM

    配置配额系统 在内核中执行以文件系统为单位启用,对不同组或者用户的策略不同; 根据块或者节点进行限制 软限制(soft limit) 硬限制(hard limit) 初始化(/home) 分区挂载选项( /etc/fstab ):usrquota、grpquota 创建数据库: 将selinux调为禁用状态:Permissive quotacheck -cu…

    Linux干货 2017-04-26
  • 第六周作业

    1、简述osi七层模型和TCP/IP五层模型 应用层 运行着应用程序的协议http、ftp、tftp等 表示层 将应用层所编辑的数据进行加密或解密,没有协议 会话层 决定一次数据传输发起和接收会话请求,没有协议 传输层 根据选着的协议类型,决定是否将数据分割或重组,协议:tcp、udp等 网络层 编辑逻辑地址信息(原站点、目的站点)和路由选着(ARP)协议:…

    2018-02-06
  • linux学习总结-linux基础(之一)

    一、计算机的组成及其功能 冯诺依曼结构的计算机由运算器、控制器、存储器和输入设备、输出设备五部分组成。冯诺依曼理论的要点是:数字计算机的数制采用二进制;计算机应该按照程序顺序执行。 控制器:控制程序执行; 存储器:记忆程序和数据; 输入设备:输入数据和程序; 输出设备:输出处理结果。 二、Linux发行版 Linux的发型版本众多,大体可以分为两类,一类是商…

    Linux干货 2016-09-23