find可以这么用

在工作中不可或缺的工具find:查找系统中的各种文件,对查找的文件进行操作,这就是find的作用。进入正题:

1、查找下系统中有一下系统中有几个文件叫issue的

    [root@localhost private]#find / -name issue

        /etc/issue
        /root/etc2017-02-28/issue
    注:find查找是精确查找,不是模糊匹配

2、现在有一个任务,需要备份一下/etc目录下的文件,只备份/etc目录当级目录下的文件

    [root@localhost private]#find /etc -maxdepth 1 -mindepth 1

        /etc/fstab
        /etc/crypttab
        /etc/mtab
        /etc/resolv.conf

        ……..

    命令中-maxdepth是最大目录递归,面mindepth是最小目录递归,而上面打示例是精确定位目录递归次数

3、下面来说说与文件类型的相关搜索

    先来回忆一下文件都有那些类型吧:

        file(f):普通文件

        directory(d):目录

        character(c):字符型设备文件

        block(b):块类型设备文件

        link(l):软链接文件

        socket(s):套接字文件

        pipe(p):管道文件

    来查看一下/etc目录一级目录中的以.conf字符结尾的普通文件

          find /etc -maxdepth 1 -mindepth 1 -type f -name “*.conf”

                   /etc/resolv.conf
                    /etc/sos.conf
                    /etc/logrotate.conf
                    /etc/host.conf
                    /etc/request-key.conf

    做个小解释吧:精确定位目录层级使用 -maxdepth 1 -mindepth 1,而定位文件时使用-type再加上文件类型,而在文件名通配方面需要加引号

4、来说说相关时间的查找吧

      查找一下最近7天发生变划的文件吧

            find ./ -mtime -7

    这个有mtime,atime,ctime之分,可还记的时间戳,就是它,所心查找对应的时间发生的不同的改变的文件就这么查吧

5、按文件大小进行查找

    这个文件大小查找有点坑,在这个值区间太坑了不好玩

        查找当前目录大于1M的目录

            find ./ -size +1M -exec ls -lh {} \;

                -rw-r–r–. 1 root root 1.8M Mar  4 15:04 ./.cache/tracker/meta.db
                -rw-r–r–. 1 root root 1.2M Mar  4 15:04 ./.cache/tracker/meta.db-wal

    在生产环境也只有这个比较常用,查看下特定目录下有那些大文件,所面的操作后面会说明

6、下面来看看权限相关的查询

      查询一下文件的其它用户有执行权限的文件

           find ./ -perm -001 -ls

    查询当前目录有执行权限的文件

        find ./ -perm /111 -ls

    注:权限匹配中-mode是并的关系,在这之中0表示不关心这一个位置,例如-111就是属主,属组,其它用户都有执行权限的文件,而/mode正好相反,是或的关系,只要有一个位置匹配上就可以输出

7、下面说说操作匹配项

    这里说个3+1吧:

    -ls:这算是3个中的一个输出list长格式

    -ok:这算是3个中的一个后面可以加命令进行操作

        固定格式是:-ok COMMAND {} \;

    -exec:这个同ok,只是进行操作时不提示 

       这里说一个示例吧,要把当前目录下的可执行文件移动到tmp目录下            

            find ./ -type f -perm /111 -exec mv {} /tmp/test/{} \;

    来说说最后的1吧xarges,这个比较给力,可以完成大批量文件操作

        find a | xargs rm

8、说一下用户相关的问题吧:

    -user,-group,-gid,-uid,-nouser,-nogroup,

    这个是查找用户的相关的参数,其中重要的就是查找没有用户,没有用户组的两个相关的参数了,这个可以强化设备安全,因为没有用户的文件,会照成设备安全隐患

9、上面介绍了这么多find的参数,但是这样的find并不强大,但是find支持或与并,这个就强大了,可以多条件进行匹配了

    非:-not

    与:-a

    或:-o

      查找var目录下的用户是root,用户组是mail的文件

        find ./ -user root -a -group mail 

    注:-a可省略

写法多,正在挖掘

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

(0)
gaomeigaomei
上一篇 2017-03-05 17:04
下一篇 2017-03-06 09:28

相关推荐

  • Haproxy+Keepalived+Varnish+LAMP+Memcacked+NFS 实现WordPress站点的动静分离

    详细说明,请点击CSDN博客的连接地址:http://blog.csdn.net/yhy1271927580/article/details/70195158

    2017-04-16
  • 6 文件系统权限(一):用户、组

    提纲 文件系统权限 3A 安全 Authentication    :  认证    –> 用户名&密码、指纹、人脸识别、DNA验证 Authorization    :  …

    Linux干货 2016-08-10
  • linux软件包安装与管理

    一、RPM包简介     linux之所以那么强大,除了linux强大的内核,还有很大一部分取决于linux的软件包,假想没有软件包,就一个内核在运行,人类需要和内核打交道是多么痛苦,但是聪明的人类发明了bash,通过bash,人就可以使用高级语言,和机器沟通,这其中的bash起始也是一个软件包,当然linux除了ba…

    Linux干货 2016-08-24
  • sed行编辑器

    Linux文本处理三剑客之一:sed(Stream Editor)流编辑器 sed:     将指定的文本文件内容逐行读取至sed的临时内存空间当中,称为"模式空间",而后逐行查看是否被sed的地址定界所匹配到,如果匹配,则执行相应的编辑操作,否则,默认将模式空间中的内容打印至标准输出  …

    Linux干货 2016-08-15
  • 马哥教育网络班21期-第五周课程练习

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行; # grep -E "^[[::space]]\+.*" /boot/grub/grub.conf 2、显示/etc/rc.d/rc.sysinit文件中以#开头,后面跟至少一个空白字符,而后又有至少一个非空白字符的行;…

    Linux干货 2016-08-08
  • iptables

      iptables(1) Firewall:隔离工具;Packets Filter Firewall;工作于主机或网络的边缘,对经由的报文根据预先定义的规则(匹配条件) 进行检测,对于能够被规则匹配到的报文实行某预定义的处理机制的一套组件;     硬件防火墙:在硬件级别实现部分功能的防…

    Linux干货 2016-11-01