zoukankan      html  css  js  c++  java
  • find命令笔记

    find 命令:

    文件查找:
    locate:
        非实时,模糊匹配,查找是根据全系统文件数据库进行的;
    # updatedb, 手动生成文件数据库
    速度快

    find:
        实时
        精确
        支持众多查找标准
        遍历指定目录中的所有文件完成查找,速度慢;
        
    find 查找路径 查找标准 查找到以后的处理运作
    查找路径:默认为当前目录
    查找标准:默认为指定路径下的所有文件
    处理运作:默认为显示

    匹配标准:
        -name 'FILENAME':对文件名作精确匹配
            文件名通配:
                *:任意长度的任意字符
                ?:0个或1个
                []
        -iname 'FILENAME': 文件名匹配时不区分大小写
        -regex PATTERN:基于正则表达式进行文件名匹配
        
        -user USERNAME: 根据属主查找
        -group GROUPNAME: 根据属组查找
        
        -uid UID: 根据UID查找
        -gid GID: 根据GID查找
        
        -nouser:查找没有属主的文件
        -nogroup: 查找没有属组的文件
        
        -type   类型
            f: 普通文件
            d:目录
            c:字符
            b:块文件
            l:连接文件
            p:管道文件
            s:套接字文件
        大小
        -size [+|-]
            #k
            #M
            #G
            
    组合条件:
        -a  都满足
        -o  或
        -not 非
        
    /tmp目录,不是目录,并且还不能套接字类型的文件
    /tmp/test目录下,属主不是user1,也不是user2的文件;

        -mtime  最近一次修改时间
        -ctime  改变时间
        -atime  访问时间    单位是天
            [+|-]#  +5至少五天未访问过   -5最近五天访问过的
        -mmin
        -cmin
        -amin    单位分钟
            [+|-]#
            
        -perm  MODE:精确匹配          根据权限查找
              /MODE: 任意一位匹配即满足条件
              -MODE: 文件权限能完全包含此MODE时才符合条件
            
            -644
            644: rw-r--r--
            755: rwxr-xr-x
            750: rwxr-x---
        find ./ -perm -001


    运作:
        -print: 显示
        -ls:类似ls -l的形式显示每一个文件的详细
        -ok COMMAND {} ; 每一次操作都需要用户确认
        -exec COMMAND {} ;
        
    1、查找/var目录下属主为root并且属组为mail的所有文件;
    find /var -user root -group mail

    2、查找/usr目录下不属于root,bin,或student的文件;
    find /usr -not -user root -a -not -user bin -a -not -user student
    find /usr -not ( -user root -o -user bin -o -user student )

    3、查找/etc目录下最近一周内内容修改过且不属于root及student用户的文件;
    find /etc -mtime -7 -not ( -user root -o -user student )
    find /etc -mtime -7 -not -user root -a -not -user student


    4、查找当前系统上没有属主或属组且最近1天内曾被访问过的文件,并将其属主属组均修改为root;
    find / ( -nouser -o -nogroup ) -a -atime -1 -exec chown root:root {} ;

    5、查找/etc目录下大于1M的文件,并将其文件名写入/tmp/etc.largefiles文件中;
    find /etc -size +1M >> /tmp/etc.largefiles

    6、查找/etc目录下所有用户都没有写权限的文件,显示出其详细信息;
    find /etc -not -perm /222 -ls   

  • 相关阅读:
    curl查询公网出口IP
    Linux scp命令
    docker 安装 MySQL 8.0
    Ubuntu下apt方式安装与更新Git
    第2章 一切都是对象
    Mave实战(1)——Maven介绍
    关于Identityserver4和IdentityServer3 授权不兼容的问题
    装箱和拆箱、类型比较
    接口自动化用例(Fitnesse)中批量获取系统链路日志
    man时括号里的数字是啥意思
  • 原文地址:https://www.cnblogs.com/jjzd/p/5731042.html
Copyright © 2011-2022 走看看