文件查找工具

文件查找

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

    比较实用的两个文件查找工具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干货 2016-11-30
  • 第六周 网络进程管理

    1、简述osi七层模型和TCP/IP五层模型 2、简述iproute家族命令 3、详细说明进程管理工具htop、vmstat等相关命令,并举例 4、使用until和while分别实现192.168.0.0/24 网段内,地址是否能够ping通,弱ping通则输出”success!”,若ping不通则输出”fail!&#82…

    2018-01-12
  • 网络实验

    一、子网划分 1、某公司申请到一个C 类IP 地址,但要连接6 个的子公司,最大的一个子公司有26 台计算机,每个子公司在一个网段中,则子网掩码应设为? 使用27位子网掩码一共可以分出8个子网 每段32个地址;每个子网有30个可用地址 0-31 32-63 64-95 96-127 128-159 160-191 192-223 224-255 2、一家集团…

    Linux干货 2016-09-09
  • 基于Corosync + Pacemaker+DRBD实现MySQL高可用集群

    前言 在众多的高可用集群解决方案中,除了Heartbeat之外,Corosync也能提供类似于Heartbeat一样的功能,而且目前RedHat官方提供的高可用集群解决方案的程序包都以Corosync为主,所以今后Corosync会逐渐取代Heartbeat。本文带来的是基于Corosync + Pacemaker+DRBD的MySQL高可用集群解决方案。 …

    Linux干货 2015-06-12
  • 8.2日作业

    8.2作业 1、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。   先将文件目录的属组变更为g1 ,chmod  g+s /data/testdir/    …

    Linux干货 2016-08-08
  • 第三周课堂练习

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@myserver ~]# whoami  root  [root@myserver ~]# who | cut -d' ' -…

    Linux干货 2016-09-19