文件查找工具

文件查找

    我们常常需要知道哪个文件放在哪里,才能够对该文件进行一些修改或维护等动作。 有些时候某些软件配置文件的文件名是不变的,但是各发行版 放置的目录则不同。 此时就得要利用一些搜寻指令将该配置文件的完整文件名捉出来,这样才能修改。

    比较实用的两个文件查找工具locate和find。

    locate 是利用数据库(数据库每天由系统自动更新)来搜寻文件名,特点是查找速度快,模糊查找,非实时查找。find 是很强大的搜寻指令,但时间花用的很大,精确查找而且是实时查找!(因为 find 是直接遍布硬盘查找)

locate

    这个 locate 使用很简单,直接在后面输入“文件的部分名称”后,就能够得到结果

    -b:只匹配路径中的基名

    -c:统计出共有多少个符号条件的文件

    -r:BRE,支持基本正则表达式

    updatedb:构建locate查找索引

    注意:索引构建过程需要遍历整个根文件系统,极消耗资源:

find:

    实时查找工具,通过遍历指定起始路径下文件层级结构完成文件查找;选项众多,功能比locate强大很多

    语法:

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

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

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

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

        查找条件        

    根据文件名和inode查找:

        -name "文件名称":支持使用glob *, ?, [], [^]

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

        -inum n 按inode号查找

        -samefile name 相同inode号的文件

        -links n 链接数为n的文件

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

    示例

    1.png

    2.png

    3.png   

    根据属主、属组查找:

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

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

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

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

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

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

    示例

    1.png

    2.png

    3.png 

    blob.png   

    blob.png

    blob.png

    根据文件类型查找:
        -type TYPE:
        f: 普通文件
        d: 目录文件
        l: 符号链接文件
        s:套接字文件
        b: 块设备文件
        c: 字符设备文件
        p: 管道文件

    示例

    blob.png

    blob.png

    blob.png

    根据文件大小来查找:
        -size [+|-]#UNIT
        常用单位: k, M, G
        #UNIT: (#-1, #]
        如: 6k 表示(5k,6k]
        -#UNIT: [0,#-1]
        如: -6k 表示[0,5k]
        +#UNIT: (#,∞)
        如: +6k 表示(6k,∞

    示例,  注意:5K的意思就是4-5K之间的大小

    blob.png

    blob.png

        注意:-5K的意思是0-4K之间的大小      

    blob.png

    blob.png

        注意:+5k的意思是5-∞

    根据时间戳:
    以“天”为单位;
        -atime [+|-]#, 以4为天的单位   
        #: [#,#+1)

        4是代表4-5那一天的文件文件名

        +#: [#+1,∞]

        +4代表大于等于5天前的文件名

        -#: [0,#)

        -4代表小于等于4天内的文件文件名

        -mtime
        -ctime

    示例:最近2天内被访问过的文件

    blob.png

    以“分钟”为单位:
        -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才会匹配

    示例    精确搜索权限 要求文件必须权限必须777

    blob.png
          /444 搜索文件中任何一位u,g,o中任意一个拥有4权限位都满足搜索条件 

    blob.png
        -444 搜索文件中每一个u,g,o都必须同时拥有4权限才满足,任何一个u,g,o没有4权限即不满足搜索条件

    blob.png

    组合条件:
        与: -a
        或: -o
        非: -not, !
    德·摩根定律:
        (非 P) 或 (非 Q) = 非(P 且 Q)
        (非 P) 且 (非 Q) = 非(P 或 Q)

        not A or not B = not (A and B)

        not A and not B = not (A or B)
        非A而且非B就是非(A或B)

        非A或非B就是非(A和B)
    具体我们还是来示例吧

    如果我要查找一个属主不是root而且属主也不是gdm的文件;

    find /home -not -user root -not -user gdm ;这里的意思就是 非A且非B,上边我们说了非A且非B=非(A或B),那就有另外一种方式

    find /home -not \( -user root -o -user gdm \);这就是非A且非B=非(A或B)啦,记死格式就偶了

    如果我要找一个属主不是root或者属主不是gdm的文件

    find /home -not -user root -o -not -user gdm;这里的意思就是非A或非B,上边提到非A或非B=非(A和B),那就有另外一种方式

    find /home -not \( -user root -a -user gdm \);这就是非A或非B=非(A和B)。

    处理动作

        最简单的处理动作有 ;-ls -delete -fls -ok cmd {} \;(-ok cmd {} \;)处理的没一个动作都会与用户交互;而且处理动作的执行与的关系优先与或的关系

        exec COMMAND {} \; 对查找到的每个文件执行由
        COMMAND指定的命令
        {}: 用于引用查找到的文件名称自身
        find传递查找到的文件至后面指定的命令时,查找到所有符合条件的文件一次性传递给后面的命令
        有些命令不能接受过多参数,此时命令执行可能会失败,下面方式可规避此问题
        find | xargs COMMAND
           

    示例

    将查找的文件的长格式信息保存到另外一个文件中

    blob.png

    将查找到文件的长格式信息打印出来

    blob.png
    将查找到的所有以f为行首的文件全部删除掉

    blob.png

    1、查找/var目录下属主为root,且属组为mail的所有文件

    blob.png
   

    2、查找/var目录下不属于root、lp、gdm的所有文件

    blob.png

    blob.png

    3、查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件

    blob.png

    

    4、查找当前系统上没有属主或属组,且最近一个周内曾被访问过的文件

    注意:因为与的优先级比或的优先级高所有或要用括号扩起来

    blob.png

    5、查找/etc目录下大于1M且类型为普通文件的所有文件

    blob.png

    6、查找/etc目录下所有用户都没有写权限的文件

    所有都没有的反面是至少有一类有

    blob.png

    7、查找/etc目录下至少有一类用户没有执行权限的文件

    blob.png

    至少有一类没有的反面是所有都有

    8、查找/etc/init.d目录下,所有用户都有执行权限,且其它用户有写权限的文件

    blob.png

 

原创文章,作者:M20-1马星,如若转载,请注明出处:http://www.178linux.com/36075

(0)
M20-1马星M20-1马星
上一篇 2016-08-21 20:45
下一篇 2016-08-21 20:45

相关推荐

  • Linux基础知识总结

    Linux基础知识 计算机系统 计算机硬件组成 1.控制器:计算机系统的控制中心,协调各部分工作,保证计算机按照预先规定的目标和步骤进行操作及处理。 2.运算器:对数据进行算数运算,逻辑判断以及数据的比较、移位等操作。 3.存储器:存取程序和各种数据信息。  4.输入设备:把信息,如数字、文字、图像等转换为数字形式的“编码”的设备(键盘,扫描仪) …

    2017-05-18
  • DNS和BIND配置(第一部分)

    一、知识整理 1、最初只有七个一级域名:Top Level Domain:tld:com、edu、mil、gov、net、org、int;     一级域名分三类:组织域、国家域、反向域。最多127级域名;全球有13个根节点服务器。 2、一次完整的查询请求经过的流程:client—hosts文件&#8212…

    Linux干货 2016-10-17
  • 硬链接与软链接

    硬连接:          其本质就是:一个文件,多个名字。注意:目录是没有硬链接的。 用ln filename linkname创建硬链接,注意源文件和链接文件位置顺序,硬链接不可以跨分区建。 在创建硬链接时会增加硬连接数,可以通过ls –l查看,如下图所示的,可看到硬链接数。…

    2017-07-20
  • N22-第十周作业

    1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) (1)POST:加电自检,利用COMS里记录的配置信息检测硬件是否都工作正常 (2)Boot Sequence: 按次序查找各引导设备,第一个有引导程序的设备即为本次启动要用到的设备 Grub引导程序:提供一个菜单,允许用户选择要启动的系统或不同的内核版本, 把用户选定的内…

    Linux干货 2016-10-25
  • 【原创】Tengine+LUA+Nginx-GridFS+jemalloc编译安装

    操作系统 ubuntu 14.04 LTS Nginx-GridFS为nginx直接访问mongoDB的扩展模块,目前只支持到mongodb2.6.12 mongodb安装请自己百度 #安装依赖包保平安 apt-get install root-system-bin autoconf automake gcc c++ libgeoip-devlibxml++…

    Linux干货 2016-11-30
  • Tomcat详解

    Tomcat详解 1、tomcat安装 tomcat的组件:<Server> <Service> <connector/> <connector/> <Engine> <Host /> <Host> <Context/> … </Host> &lt…

    2017-04-27