文件查找find和locate

        在Linux这个一切皆文件的系统中怎么能快速和精确的查找到文件,是我们必不可少的技能。而文件查找的命令可以让我们在很短的时间内在文件系统中找到我们要查找的文件。这就是我们要掌握的,因此我来介绍一下文件查找的这两个命令locate和find。

文件查找:在文件系统上查找符合条件的文件;

文件查找:locate, find

    非实时查找( 数据库查找) :locate

    实时查找:find

locate命令

查询系统上预建的文件索引数据库 :/var/lib/mlocate/mlocate.db

依赖于事先构建的索引;

        索引的构建是在系统较为空闲时自动进行( 周期性任务) ;管理员手动更新数据库(updatedb); ;索引构建过程需要遍历整个根文件系统,极消耗资源;

工作特点:

    查找速度快;

    模糊查找;

    非实时查找;

    搜索的是文件的全路径,不仅仅是文件名可能只搜索用户具备读取和执行权限的目录。

locate 命令语法

locate KEYWORD

locate passwd:搜索名称或路径中带有“passwd ”的文件

lockate.PNG

有用的选项

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

locate -i.PNG

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

locate -n.PNG

find命令

实时查找工具,通过遍历指定路径完成文件查找;

工作特点:

    查找速度略慢

    精确查找

    实时查找

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

find命令语法:

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

    查找路径:指定具体目标路径;默认为当前目录

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

    处理动作:对符合条件的文件做操作,默认输出至屏幕

查找条件

根据文件名和inode 查找:

    -name " 文件名称" :支持使用glob

        *, ?, [], [^]

    -iname " 文件名称" :不区分字母大小写

    -inum n 按inode 号查找

    -samefile name 相同inode 号的文件

    -links n 链接数为n 的文件

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

文件查找find和locate

文件查找find和locate

根据属主、属组查找:

    -user USERNAME :查找属主为指定用户(UID) 的文件

    -group GRPNAME:  查找属组为指定组(GID) 的文件

    -uid UserID :查找属主为指定的UID 号的文件

    -gid GroupID :查找属组为指定的GID 号的文件

    -nouser :查找没有属主的文件

    find -nouser.PNG

    -nogroup :查找没有属组的文件

find -nogroup.PNG

根据文件类型查找:

    -type TYPE:

    f:  普通文件

    d:  目录文件

find -type d.PNG

    l:  符号链接文件

    s :套接字文件

    b:  块设备文件

find -type b.PNG

    c:  字符设备文件

    p:  管道文件

根据文件大小来查找:

-size [+|-]#UNIT

常用单位:k, M, G

#UNIT: (#-1, #] ,如:6k

-#UNIT :[0,#-1],  如:-6k

+#UNIT :(#, ∞ ), 如:+6k

find.PNG

6k  :是5k – 6k 之间,不包含5k,但包含6k。

-6k   :是0k – 5k 之间,不仅包含0k, 也包含5k。

+6k :是6k-正无穷之间,不包含6k。

find -size.PNG

根据时间戳:

以“天”为单位;

find -mtime.PNG

以“分钟”为单位:

    -amin

    -mmin

    -cmin

find -amin.PNG

根据权限查找:

-perm [/|-]MODE

MODE:  精确权限匹配

    /MODE :任何一类(u,g,o) 对象的权限中只要能一位匹配即可,或关系,+  从centos7 开始淘汰

    -MODE :每一类对象都必须同时拥有指定权限,与关系

    0  表示不关注

find -perm 755 会匹配权限模式恰好是755 的文件

只要当任意人有写权限时,find -perm /222 就会匹配

只有当每个人都有写权限时,find -perm -222 才会匹配

只有当其它人(other )有写权限时,find -perm -002才会匹配

find -perm.PNG

组合条件:

    与:-a

    或:-o

    非:-not, !

find -o.PNG

find -not.PNG

    德· 摩根 定律:

        非(P 且 Q) = (非 P) 或 (非 Q)

        非(P 或 Q) = (非 P) 且 (非 Q)

   !A -a !B = !(A -o B)

   !A -o !B = !(A -a B)

德摩根.PNG

德.摩根定律.PNG

P=1+3 , Q=2+3 , P 且 Q=3 , P 或 Q=1+2+3

非(P 且 Q) = (非 P) 或 (非 Q)

    非(P 且 Q):非(1+3 且 2+3)=(2+4 或 1+4)= 1+2+4

    (非P)或(非Q): (非 1+3)或(非2+3)=(2+4)或(1+4)= 1+2+4

    (可以看出除了3其他都是)

非(P 或 Q) = (非 P) 且 (非 Q)
    非(P 或 Q):非(1+3 或 2+3)=(2+4 且 1+4)= 4

    (非P)且(非Q) :(非 1+3)且(非 2+3)=(2+4)且(1+4)=4

    (可以看出除了4其他都不是)

排除目录

find /etc -path ‘/etc/sane.d’ -a -prune -o -name *.conf -print

文件查找find和locate

find 排除目录.PNG

处理动作

-print :默认的处理动作,显示至屏幕;

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

-delete :删除查找到的文件;

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

-ok COMMAND {} \;  对查找到的每个文件执行由COMMAND 指定的命令;

对于每个文件执行命令之前,都会交互式要求用户确认

-exec COMMAND {} \;  对查找到的每个文件执行由COMMAND 指定的命令

{}:  用于引用查找到的文件名称自身

find 传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令

有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题

find | xargs COMMAND

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

(0)
AN0519AN0519
上一篇 2016-08-24
下一篇 2016-08-24

相关推荐

  • M22 用户、组学习总结

    Linux系统的登录方式是通过账号和密码。每一个登录账号都有一个主组可能有附加组。Linux内的文件和目录都有所有者和属组,只有相应权限的账户可以对其进行操作,下面我对用户权限相关内容进行了总结。   1、  用户ID,每个用户具有相应的ID号码,主要分为两类:系统ID和用户ID,在Centos6中系统ID为1-499,用户ID >…

    2017-02-22
  • Linux系统启动流程与内管管理(上)

    在讲linux系统启动流程之前,来讲讲linux的组成,这样能能帮助我们深入了解系统的启动流程,废话不多说直接上系统启动流程图 linux组成 linux:kernel+rootfs kenrel的作用:进程管理、内存管理、网络管理、驱动程序、文件系统、安全管理等   rootfs:程序和glibc 库:函数结合,function,调用接口(头文件…

    系统运维 2016-09-14
  • Mysql cmake 编译安装、

    基于cmake的mysql安装 1.1 前言 从mysql5.5起,mysql源码安装的编译工具configure开始向cmake过渡。安装方式和之前的略有不同。在这里简单介绍总结下。 安装之前,检查下GNU make, GCC, Perl, libncurses5-dev,cmake-2.8.4是否都已经安装,如果没有安装,用yum install 安装补…

    Linux干货 2017-08-29
  • shell脚本的各种循环

    For循环 For循环格式      For   变量名  in    列表    ;   do         &nb…

    Linux干货 2016-08-21
  • 【25期】Linux第一周学习知识小结

    1:设置Linux图形界面不用输入账号和密码直接登录系统 首先在图形化界面编辑文件:vi /etc/gdm/custom.conf 编辑如下图: 在[daemon]下添加两行代码: AutomaticLoginEnable=True // 自动登陆器用 AutomaticLogin=root   //登录账号root 2:free命令 在终端输入f…

    2017-07-15
  • 设计模式(十一)代理模式Proxy(结构型)

    1.概述        因为某个对象消耗太多资源,而且你的代码并不是每个逻辑路径都需要此对象, 你曾有过延迟创建对象的想法吗 ( if和else就是不同的两条逻辑路径) ? 你有想过限制访问某个对象,也就是说,提供一组方法给普通用户,特别方法给管理员用户?以上两种需求都非常类似,并且都需要解决一个更大的问题:你如何提供…

    Linux干货 2015-07-09