find 命令使用

find

命令使用格式:find        pathname        -options        [-print] 

                      命令名字      路径名称                选项                输出 

参数:

pathname:  find命令所查找的目录路径,不输入代表当前目录例如用 . 来表示当前目录,用 / 来表示系统根目录。

find命令选项:

 -name    按照文件名查找文件。  “名称”

 -perm    按照文件权限来查找文件。666 777 等

 -user      按照文件属主来查找文件

 -group     按照文件所属的组来查找文件

 -mtime  -n  / +n  按照文件的更改时间来查找文件,

                - n 表示文件更改时间距现在n天以内

                + n 表示文件更改时间距现在n天以前

-type     查找某一类型的文件

               b      块设备文件

               d      目录

               c       字符设备文件

               p      管道文件

               l       符号链接文件

               f      普通文件

-size n  查找符合指定的文件大小的文件

-exec    对匹配的文件执行该参数所给出的其他linux命令, 相应命令的形式为' 命令 {} \;,注意{ }和 \;之间的空格,{}代表查到的内容

例1:查看当前目录下所有的TXT格式的文件

[root@xuegod63 mnt]# find . -name "*.txt"

./a.txt

./xuegod.txt

2、按照更改时间或访问时间等查找文件

如果希望按照更改时间来查找文件,可以使用mtime,atime或ctime选项

        mtime:  文件最后一次修改的时间

        atime:  最后一次访问时间

        ctime:  文件的最后一次变化时间,也就是修改时间

例1:希望在root目录下查找更改时间在1天以内,被黑客修改的文件

[root@xuegod63 ~]# find /root/ -mtime -1


3、对查找内容执行相应命令

image.png

-exec    这个选项参数后面可以跟自定义的SHELL命令,格式如下:

例2:

[root@xuegod63 ~]# touch {1,2,3}.back

[root@xuegod63 mnt]# find . -name "*.back" -exec ls -l {} \;

例3:

[root@xuegod63 ~]#  find . -name "*.back" -exec mv {} /opt \;

[root@xuegod63 ~]# ls /opt/

1.back  2.back  3.back  rh  xuegod.txt

例4:把查找到的文件复制到一个指定的目录

[root@xuegod63 mnt]# find /root -name "*.txt" -exec cp {} /opt  \;

例5:xargs和find命令结合 复制文件    -i  表示 find 传递给xargs的结果 由{}来代替  (了解)

[root@xuegod63 ~]# rm -rf /opt/*

[root@xuegod63 ~]# find . -name "*.txt"  | xargs  -i cp {}  /opt

[root@xuegod63 ~]# ls /opt/

例6:查找多个类型文件

比较符的使用:

    -a  and 并且

    -o  or  或者

    +  超过

    -   低于

[root@xuegod63 ~]# touch a.pdf back.sh

[root@xuegod63 ~]# find . -name "*.sh" -o -name "*.pdf"

[root@xuegod63 ~]# find /etc -size +20k -a -size -50k | wc -l

22

[root@xuegod63 ~]# find /etc -size +20k  | wc -l

49

例7:  按权限查找:-perm

[root@xuegod63 ~]# find /bin/ -perm 755   # 等于0755权限的文件或目录

[root@xuegod63 ~]# find /bin/ -perm  -644   #-perm -644  至少有644权限的文件或目录

例:查看系统中权限至少为777的文件或目录

创建一些测试文件:

[root@xuegod63 ~]# mkdir ccc

[root@xuegod63 ~]# chmod 777 ccc

[root@xuegod63 ~]# mkdir test

[root@xuegod63 ~]# chmod 1777 test

[root@xuegod63 ~]# touch b.sh

[root@xuegod63 ~]# chmod 4777 b.sh

查找:

[root@xuegod63 ~]# find /root/ -perm 777

[root@xuegod63 ~]# find /root/ -perm 1777

[root@xuegod63 ~]# find /root/ -perm  4777

例:把系统中权限不低于777的危险目录查找出来

[root@xuegod63 ~]# find /root/ -perm  -777

例:把系统中权限不低于777的危险文件查找出来

[root@xuegod63 ~]# find / -type f -perm  -777

例8:查找的目录深度

-maxdepth 1  #只查找目录第一层的文件和目录

如:查找/bin目录下权限等于755的可执行的文件

[root@xuegod63 ~]# find /bin/ -maxdepth 1 -perm 755  #/bin后面要有/

[root@xuegod63 ~]# find /bin -maxdepth 1 -perm 755  #这个命令无法满足我们的需求

例9:查找系统中所有属于用户mk的文件,并把这个文件,放到/root/findresults目录下

注意:/root/findresults这个需要提前创建好。

[root@xuegod63 ~]# mkdir /root/findresults

[root@xuegod63 ~]# find / -user mk -exec cp -a {} /root/findresults/  \;

#参数: -a  #复制时,保留原来文件的所有属性

报错:

find: ‘/proc/43475/task/43475/fd/6’: 没有那个文件或目录

find: ‘/proc/43475/task/43475/fdinfo/6’: 没有那个文件或目录

find: ‘/proc/43475/fd/6’: 没有那个文件或目录

find: ‘/proc/43475/fdinfo/6’: 没有那个文件或目录

cp: 无法以目录"/home/mk" 来覆盖非目录"/root/findresults/mk"

互动: 同一个目录下,可以创建文件mk和文件夹mk吗?同一个目录下创建的文件名和目录名一样吗?

答:不可以

解决:

[root@xuegod63 ~]# find / -user mk  #发现

[root@xuegod63 ~]# ll /var/spool/mail/mk  #查看这个文件

[root@xuegod63 ~]# ll /home/mk  

发现/var/spool/mail/mk 和/home/mk 的名字是一样的。 而两者都要复制到/root/findresults/下,先复制了/var/spool/mail/mk,所以/home/mk就不能复制了。

[root@xuegod63 ~]# mv /var/spool/mail/mk  /var/spool/mail/mk.mail

[root@xuegod63 ~]# rm -rf /root/findresults/*

[root@xuegod63 ~]# find / -user mk -exec cp -a {} /root/findresults/  \;

[root@xuegod63 ~]# mv /var/spool/mail/mk.mail  /var/spool/mail/mk  #再修改过来

版权声明:
作者:WaterBear
链接:https://l-t.top/1400.html
来源:雷霆运维
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
< <上一篇
下一篇>>