文件查找工具

文件查找

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

    比较实用的两个文件查找工具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
下一篇 2016-08-21

相关推荐

  • Linux磁盘管理命令

    Linux有着管理各种存储设备的强大能力。Linux把所有磁盘都当作文件管理,从而简化我们对其进行的读写等操作。 IDE接口的硬盘在Linux中命名为:/dev/hd{a|b|c……},比如/dev/hda; 其他硬盘比如SATA接口的硬盘命名为:/dev/sd{a|b|c……},比如/dev/sda。 注:{…

    Linux干货 2015-12-06
  • vim简单总结

    编辑器种类 常用的文本编辑器有: 行编辑器,如sed,awk,cut等 全屏编辑器,如vi,vim(vi增强版),nano等 vim的模式 命令模式:使用vim filename打开文件后,进入的第一个模式。 直接使用键盘操作文本的编辑 插入模式:INSERT模式 进入:i,从当前光标处开始 进入:I,从当前行行首开始 末行模式:vim内置命令接口。 以:开…

    Linux干货 2016-08-18
  • 第一篇博客

    我的第一篇博客以及接下来的每一篇都要献给linux运维了。第一次接触linux是在大三的时候,当时并没有想到以后还会和linux邂逅并以此谋生。 首先就从最基础的linux分区与挂载点开始了解介绍,我们熟悉的Windows系统下的分区都分配有盘符,像c盘,d盘之类的,用来存放各种软件和文件。而linux也有自己的分区,并将分区挂载到不同的挂载点上,挂载是指将…

    2017-07-16
  • ansible的用法

    ansible 每台主机拥有不同的功能,可能同时是http服务器,php-fpm的客户端,共享存储的客户端等,这些功能是单独定义的,不同主机需要的功能各不相同 应确保目标主机的状态为事先给他定义的目标状态 使目标主机达到目标状态有两种方法      agentless:由服务端主机通过ssh连接到目标主机执行命令,客户端不需要额…

    Linux干货 2016-11-11
  • linux的终端类型

    Linux系统的终端类型    Linux系统的终端主要包括控制台终端、控制终端、串口终端、伪终端、虚拟终端。                 1.  控制台终端(/dev/console)。    在Unix系统中,计…

    Linux干货 2016-10-19
  • sed使用小结

    sed使用小结 Stream EDitor  行编辑器       sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”( pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,…

    Linux干货 2016-08-12