Linux文件查找之find命令

前言:   

    Linux文件种类繁多,难免在维护Linux中会忘记文件的路径。所有在维护Linux中学好查找命令是非常必要的。

    Linux查找命令有很多,比如 whereis,type,which,locate,find(重点)。

        1、whereis

                whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。

                whereis命令的使用实例:

QQ截图20150608101211.png

       2、type

                type命令其实不能算查找命令,它是用来区分某个命令到底是由shell自带的,还是有shell外部的独立二级制文件提供的。如果一个命令是外部命令,那么使用-P参数,会显示该命令的路径,相当于which命令。

                type命令的使用实例:

QQ图片20150608130234.png

       3、which

                which命令的作用是在PATH变量指定的路径中,搜索某个系统命令的位置,并且返回第一个搜索结果。也就是说,使用which命令就可以看到系统命令是否存在,以及执行的到底是哪一个位置的命令。

常用参数:--skip-alias:去除别名。

                which命令的使用实例:

QQ截图20150608110929.png

        这里cd命令是内建命令,因而无法查到。

        

        4、locate

                locate查找为非实时查找,也成模糊查找。locate依赖于索引,而索引构建时在系统空闲时由系统自动进行(每天任务);手动进行使用updatedb;locate命令的优势是查找速度快,劣势为非精准查找。

                locate命令使用实例:
                    locate的参数:
                        -n #:限定显示#行
                        -i:不区分大小写,默认区分
                        -r FILE_NAME:显示以FILE_NAME为结尾的行

QQ截图20150608144729.png

QQ截图20150608153537.png

            关于locate的其他参数使用,这里就不做详细讲解了,还请朋友们自行Google

        5、find(重点)

                find命令是遍历所有文件进行条件匹配,查找速度慢但结果精确,即为精准查找。也是我们在生产环境中使用最多,最强大的文件查找工具。

           find的使用格式:
                find [option]... [查找路径] [查找条件] [处理动作]
                    查找路径:默认为当前目录
                    查找条件:默认为指定路径下的所有文件
                    处理动作:默认为显示至屏幕

        查找条件:

            -name “文件名称”:支持使用文件通配(globbing)字符
                     *:任意长度任意字符
                    ?:任意单个字符
                    [ ]:指定范围内的单个字符
            -iname “文件名称”:查找时忽略字符大小写
            -user USERNAME:根据属主查找
            -group GRPNAME:根据文件属组查找
            -uid UID
            -gid GID
            -nouser:没有属主的文件
            -nogroup:没有属组的文件

        组合条件查找:

            与:-a,同时满足
            或:-o,满足一个即可
            非:-not,!,条件取反
                注:-not A -a -not B = -not\(A -o B\)
                       -not A -o -not B = -not\(A -a B\)

        -type TYPE:根据文件类型查找

             f:普通文件
                d:目录文件
                l:符号链接
                b:块设备
                s:套接字文件
                p:命令管道

        -size [+|-]#UNIT(单位)

              常用单位:k,M,G
                #UNIT:#-1<x<#
                -#UNIT:x<=#-1
                +#UNIT:x>#

        根据时间戳查找:

            以“天”为单位
                -atime(访问时间) [+|-]#
                    +#:(#+1)天之前被访问过的文件 x>=#+1
                    -#:x<#
                    x:#<=x<#+1
                        例如:+2:最近一刻访问文件的时间是2天以前
                                  -2:访问文件的时间是当前时间之2天之内
                                    2:访问文件的时间大于2天小于3天
                -mtime(修改时间):
                -ctime(改变时间):
                用法同atime。

        以“分钟”为单位 

              -amin
              -mmin
              -cmin

        根据文件权限查找:

               -perm [+|-]MODE
                    MODE:与MODE精确匹配
                    +MODE:任何一类用户的取消只要包含对其指定的任何一位权限即可
                    -MODE:每一类用户指定的检查权限都匹配;

        处理动作:           

    -print:默认处理动作,显示
                -ls:类似于ls -l显示详细信息
                -exec COMMAND {} \;
                -ok COMMAND {} \;
                    注:一次性查找符合条件的所有文件,并一同传递给-exec或-ok后面指定的命令;但有些命令不能接受过长的参数;此时使用另一种方式
                    find  | xargs COMMAND

    实战演示:

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

QQ截图20150608210555.png

2、查找/usr目录下不属于root、bin或hadoop的所有文件

QQ截图20150608211042.png

3、查找/etc/目录下最近一周内其内容修改多的,且不属于root或hadoop的文件;

QQ截图20150608211809.png

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

QQ截图20150608212624.png

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

QQ截图20150608212822.png

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

QQ截图20150608213127.png

7、查找/etc/目录下至少有一类用户没有写权限;

QQ截图20150608214309.png

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

QQ截图20150608214646.png

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

(0)
水蒸气水蒸气
上一篇 2015-06-15 18:21
下一篇 2015-06-16 21:31

相关推荐

  • Linux-文件基本权限及特殊权限详解

    Linux文件基本权限及特殊权限详解 背景 Linux文件基本权限和特殊权限对于初学者很少烦恼,各种无法理解,所以在学到这一节时,将自己学到的以及自己的理解写出来以检查自己对这个部分的掌握情况。 什么是权限 在Linux里一切皆文件,所谓的权限就是用户对文件(目录也是以个文件)的操作范围,对文件的操作包括读、写和执行,用户对文件有不同的权限就能做相应的操作。…

    Linux干货 2017-07-22
  • 文件查找与压缩-2

    1、tar [OPTION]… (1) 创建归档(打包而非压缩) 其中-c是创建备份,-f是指定创建备份成的文件即是/PATH/TO/SOMEFILE.tar #tar -c -f /PATH/TO/SOMEFILE.tar  FILE… #tar cf / PATH/TO/SOMEFILE.tar FILE… …

    Linux干货 2016-08-18
  • 密码保护:第二天

    无法提供摘要。这是一篇受保护的文章。

    Linux干货 2017-07-15
  • linux小小小入门。

      ❀用户登录:     ❤root用户 这是一个特殊的管理账户,也被称为超级账户,root已经接近完整的系统控制。但是对系统的损害有非常广泛的能力。(一般情况下不会登录root)     ❤普通用户 权限有限,损害能力较小。 ❀终端terminal:     ❤设备终端 键盘,鼠标,显示器     &#x…

    Linux干货 2018-03-26
  • 回溯法 -数据结构与算法

    1.回溯法算法思想: 定义:         回溯法(探索与回溯法)是一种选优搜索法,按选优条件向前搜索,以达到目标。但当探索到某一步时,发现原先选择并不优或达不到目标,就退回一步重新选择,这种走不通就退回再走的技术为回溯法,而满足回溯条件的某个状态的点称为“回溯点”。 1、回溯法适用:有许多问题,当需要找出它的解集(…

    Linux干货 2015-04-07
  • PXE自动化安装系统服务

    PXE PXE(preboot execute environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服务器下载映像,并由此支持通过网络启动操作系统,在启动过程中,终端要求服务器分配IP地址,再用TFTP(trivial file transfer protocol)或M…

    Linux干货 2016-11-07