• linux下find命令的使用和总结


    背景:find命令十分的好用,特别是在查找文件的时候,这个时候需要和文件通配符一起使用。

     

    1 前言

    我们为什么要学会使用find命令?

    每一种操作系统都有成千上万的文件组成,对于linux这样“一切皆文件”的操作系统来说更不例外,大家应该都能很轻松使用windows下的文件查找功能,但是对linux这一功能可能并不是很熟悉。

    其实想玩linux的你更要牢牢掌握这个命令,因为linux不像windows那样有固定的文件名后缀,并且因为linux阵营下百家争鸣的特性,一个相同的文件在不同的发行版,可能会有不同,所以如果你能牢牢掌握find命令的使用,你在摸索linux的道路上将会顺利很多,同时你会发现linux下文件查找功能其实很简单,而且要比windows下查找功能强大很多很多!好,下面进入正题

    2 find介绍 

    Linux下查找文件的命令有两个:locate 和 find

    首先说下locate,locate这个命令是对其生成的数据库进行遍历(生成数据库的命令:updatedb),这一特性决定了用locate查找文件速度很快,但是locate命令只能对文件进行模糊匹配,在精确度上来说差了点,简单介绍下它的两个选项:

      #locate 
    
            -i        //查找文件的时候不区分大小写 比如:locate  –i   passwd
    
           -n       //只显示查找结果的前N行     比如:locate  -n  5   passwd

    下面重点说下find,find在不指定查找目录的情况下是对整个系统进行遍历查找

     2.1 语法

      使用格式 :  

     find  [指定查找目录]  [查找规则]  [查找完后执行的action]

      [指定查找目录]例如:

     

    ps:这里要注意的是目录之间要用空格分开

     2.2 查找规则

    [查找规则

        

    (1)根据文件名查找

     #  -name       //根据文件名查找(精确查找)
    
     #  -iname       //根据文件名查找,但是不区分大小写 

    这里另外介绍下文件名通配符的知识

    *表示  通配任意的字符

               

     

    ?表示  通配任意的单个字符

     

             

    [ ] 表示 通配括号里面的任意一个字符

     

         (2)根据文件所属用户和组来查找文件

    #  -user         //根据属主来查找文件
    
     #  -group        //根据属组来查找文件

              (3)根据uid 和 gid来查找用户

     #find  /tmp  -uid  500  //查找uid是500 的文件
    
     #find  /tmp  -gid  1000 // 查找gid是1000的文件

              (4)-a  and  -o  and  –not的使用

    ps:有用

    # -a 连接两个不同的条件(两个条件必须同时满足)
    
    # -o 连接两个不同的条件(两个条件满足其一即可)
    
    # -not 对条件取反的

     

          

        (5)根据文件时间戳的相关属性来查找文件

              我们可以使用stat命令来查看一个文件的时间信息 如下:

     

          
    复制代码
               #-atime
    
               #-mtime
    
               #-ctime
    
               #-amin
    
               #-mmin
    
               #-cmin
    复制代码

       所以这里atime,mtime,ctime就是分别对应的“最近一次访问时间”“最近一次内容修改时间”“最近一次属性修改时间”,这里的atime的单位指的是“天”,amin的单位是分钟  

     

              #find  /tmp  –atime  +5           //表示查找在五天内没有访问过的文件(也就是5天前天没访问的文件)

              #find  /tmp  -atime  -5            //表示查找在五天内访问过的文件

              ps:在清理日志的时候,一般使用的是——最近一次内容修改的时间

    find -mtime +30 -name "*[0-9]*" -exec rm {} ;

              (6)根据文件类型来查找文件

    复制代码
              -type
    
                          f     // 普通文件
    
                          d     //目录文件
    
                          l     //链接文件
    
                          b     //块设备文件
    
                          c     //字符设备文件
    
                          p     //管道文件
    
                          s     //socket文件                
    复制代码

             

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

                   -size

              #find  /tmp  -size   2M           //查找在/tmp 目录下等于2M的文件

              #find  /tmp  -size  +2M           //查找在/tmp 目录下大于2M的文件

              #find  /tmp  -size  -2M           //查找在/tmp 目录下小于2M的文件

               (8)根据文件权限查找文件

                  -perm

              #find  /tmp  -perm  755           //查找在/tmp目录下权限是755的文件

              #find  /tmp  -perm  +222          //表示只要有一类用户(属主,属组,其他)的匹配写权限就行

              #find  /tmp  -perm  -222          //表示必须所有类别用户都满足有写权限

               (9)-nouser  and  -nogroup

              #find  /  -nogroup –a –nouser       //在整个系统中查找既没有属主又没有属组的文件(这样的文件通常是很危险的,作为系统工程师的我们应该及时清除掉)

      2.3 [查找完执行的action]

    复制代码
             # -print                                 //默认情况下的动作
    
             # -ls                                     //查找到后用ls 显示出来
    
             # -ok  [commend]                //查找后执行命令的时候询问用户是否要执行
    
            # -exec [commend]              //查找后执行命令的时候不询问用户,直接执行
    复制代码

     

    这里要注意{}的使用:替代查找到的文件

     

    #删除查找到的超过30天没有访问过文件  
    find  /tmp  -atime  +30  –exec rm –rf  {}  ; 

         我们也可以使用xargs来对查找到的文件进一步操作

        
    ………………………………………………………………………………………ok!     以上就是关于find的使用方法,排版有点失败,主要是字体调粗后无法调细了,悲催……但是希望各位读者看完这边博客后能有所收获…
     3 补充知识

    1.删除文件命令:

    find 对应目录 -mtime +天数 -name "文件名" -exec rm -rf {} ;

    实例命令:

    find /opt/soft/log/ -mtime +30 -name "*.log" -exec rm -rf {} ;

    说明:

    将/opt/soft/log/目录下所有30天前带".log"的文件删除。具体参数说明如下:

    find:linux的查找命令,用户查找指定条件的文件;

    /opt/soft/log/:想要进行清理的任意目录;

    -mtime:标准语句写法;

    +30:查找30天前的文件,这里用数字代表天数;

    "*.log":希望查找的数据类型,"*.jpg"表示查找扩展名为jpg的所有文件,"*"表示查找所有文件,这个可以灵活运用,举一反三;

    -exec:固定写法;

    rm -rf:强制删除文件,包括目录;

    {} ; :固定写法,一对大括号+空格++; 

  • 相关阅读:
    Mysql索引优化
    [ExtJS5学习笔记]第六节 Extjs的类系统Class System命名规则及定义和调试
    [ExtJS5学习笔记]第五节 使用fontawesome给你的extjs5应用增加字体图标
    【翻译】Ext JS 5.0.1 中的新功能
    OpenCV——PS图层混合算法(六)
    [IDE工具配置]myeclipse 2014 专业版 安装 svn插件
    OpenCV——PS 图层混合算法 (四)
    [ExtJS5学习笔记]第四节 欢迎来到extjs5-手把手教你实现你的第一个应用
    [ExtJS5学习笔记]第三节 sencha cmd学习笔记 生成应用程序构建的内部细节
    [ExtJS5学习笔记]第二节 Sencha Cmd 学习笔记 使你的sencha cmd跑起来
  • 原文地址:https://www.cnblogs.com/surplus/p/11441390.html
Copyright © 2020-2023  润新知