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
下一篇 2015-06-16

相关推荐

  • 文件系统知一二

    文件系统知一二 What?文件系统是什么?     我们经常说文件系统,那么文件系统是什么东西呢?    计算机的文件系统是一种存储和组织计算机数据的组织结构。 常见的文件系统有哪些?           &n…

    Linux干货 2016-03-09
  • Linux运维学习历程-第六天-Linux用户、组以及权限管理

    本章内容    Linux的安全模型    用户和组    用户和组管理命令    文件权限    默认权限    特殊权限    ACL访问控制 一:3A认证       &nb…

    Linux干货 2016-08-07
  • 学习Linux,记得有困难,找“男人”。

      对于Linux初学者而言,较短时间内需要涉及到几十个命令,而且每个命令还可辅以短选项、长选项…让初学者在实践时苦不堪言。   一头雾水时,请找Super"man"!  "man"的使用非常简单,命令行直接输入man COMMAND,如#man ls。此处的COMMAND均指…

    Linux干货 2016-01-15
  • 文本处理工具sed的使用以及Vim的使用技巧详解

    一、什么是sed     sed的英文全称是Stream EDitor,叫行编辑器。     sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容…

    Linux干货 2016-08-11
  • 马哥教育网络班22期+第九周课程练习

    1. 写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin);分别这两类用户的个数;通过字符串比较来实现; #!/bin/bash#declare -a loginuserdeclare -i sum_login=0declare -i sum_nologin=0list=($(cat /et…

    Linux干货 2017-01-03
  • httpd

      httpd http服务器程序:   httpd (apache) nginx lighttpd httpd的特性:   高度模块化: core + modules DSO:dynamic shared object(模块的动态加载) MPM:Multipath processing Modules (多路处理模块) &nb…

    Linux干货 2017-06-04