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

相关推荐

  • zabbix之报警功能的实现

    一、注册微信公众号 首先申请微信公众平台https://mp.weixin.qq.com/一个人最多申请5个公众号,所以还是可以的 申请完之后就可以根据腾讯的提示使用微信公众号了,然后用你自己的微信扫描关注微信号。 就可以看到用户数了,接下来的就要使用的用户的微信ID号了。点击用户查看用户的微信ID号。在浏览器查看用户的微信ID号。就是那个红色的ID了。 h…

    Linux干货 2017-03-27
  • linux文件管理类命令学习总结练习

    1、常用文件管理类命令:cp, mv, rm   cp: copy命令       单元复制 cp [OPTION]… [-T] SOURCE DEST                     DEST不存在…

    Linux干货 2016-11-06
  • ansible进阶(roles应用)

    ansible 进阶 一、roles简介 一个项目从开始到结束,不是简单几十个playbook就可以完事了,当文件数很多,有上百个的话,仅通过简单的includes不停的引用,那最终的结果错综复杂。这个时候ansible roles就可以很好的发挥它的作用了。 roles,字面意思是角色的含义,可以理解为有相互关联功能的集合。我们把安装ntp、mem、ngi…

    2017-01-05
  • Recycled和Recycler的故事

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://jeffyyko.blog.51cto.com/28563/156012      首先说明一下,这里不是英语课堂,本文也不是来辨析Recycled和Recycler这两个单词的含义。Recy…

    Linux干货 2015-03-25
  • ntp时间服务器搭建实例

    ntp时间服务器采用stratum分级架构来处理时间同步;举例说明:你搭建了一台ntp服务器,然后同步的server为stratum-1,你的ntp则为stratum-2,你的下级ntp则为tratum-3。依此类推,最多为15层。 1.ntp server安装: [root@localhost ~]# yum -y …

    Linux干货 2015-11-10
  • linux中的权限和ACL

    linux中权限详解和ACL

    2017-11-18