谢烟客---------Linux之find查找
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了谢烟客---------Linux之find查找相关的知识,希望对你有一定的参考价值。
查找的区别
grep 根据PATTERN逐行匹配目标文本,打印字串所在行至标准输出
find 根据查找条件在给定的路径下,查找文件名对应的文件
查找的分类
实时查找: find
根据用户给出的路径,在路径下查找
非实时查找:locate,whatis
依据事先构建的索引,在数据库中查找
手动更新数据库的命令: updatedb, makewhatis
查找的特性
find:实时。速度慢。精确匹配
locate: 非实时。速度快。模糊匹配
查找语法
2、获取帮助 # man find 或 find --help 3、命令格式 find [OPTIONS...] [给出路径] [查找条件] [处理动作]
[给出路径]: 目录的路径,默认为当前工作目录。
[查找条件]: 指定查找的过滤条件:文件名、属主、属组、大小、权限、时间戳,默认为指定路径下的所有文件和目录
[处理动作]: 对查找的文件执行的操作,默认为标准输出
1、全默认时,当前工作目录下的所有文件及目录 # find . ./.font-unix ./.X1-lock .... 2、查找指定路径下的所有文件及目录 # find /etc ... /etc/openldap/schema/samba.schema /etc/services /etc/virc /etc/netconfig /etc/named.conf /etc/sudoers
一、处理动作
-ls 类似ls -l,对所有查找到的文件或目录执行 ls -l操作。
-delete 删除查找到的文件
-fls /PATH/TO/SOMEFILE查找到的文件的长格式信息保存至指定的文件中
执行命令的格式注释
{} 代表每个被操作的文件
\; 固定语法
-ok COMMAND {} \; 查找到的每个文件将交互式的执行由COMMAND指定的命令
-exec COMMAND {} \; 查找到的每个文件直接执行由COMMAND指定的命令
注意:find 命令会将符合条件的内容,一次性传递给后面的命令,有些命令或许不支持过多的参数,
此时我们应该使用
find [OPTIONS...] [给出路径] [查找条件] [处理动作] | xargs COMMAND xargs命令总结: [[email protected] tmp]# type xargs xargs is /usr/bin/xargs [[email protected] tmp]# xargs --help Usage: xargs [OPTION]... COMMAND INITIAL-ARGS... 默认以空白字符构建单行,将多行转换为单行,或将单行转换为多行 -d, --delimiter=CHARACTER 定义定界符 -E END 定义结束符 -n, --max-args=MAX-ARGS 每行最大的参数 -I R 将输入的每个数据赋值给R,可供R调用。R可为任意数 # cat a.txt a b c d e f g h i j k 1、将多行构建为单行 [[email protected] ~]# cat a.txt | xargs a b c d e f g h i j k 2、-n选项 [[email protected] ~]# cat a.txt | xargs -n4 a b c d e f g h i j k 3、-d选项 [[email protected] ~]# echo "howXareXyou?" | xargs -d‘X‘ how are you? [[email protected] ~]# 4、-I R 选项 [[email protected] tmp]# echo "a b c d" | xargs -I R echo R a b c d [[email protected] tmp]# echo "a b c d" | xargs -I {} echo {} a b c d
为了避免系统的文件不被误操作, # cd /tmp
-ls 类似ls -l,对所有查找到的文件或目录执行 ls -l操作。
1、当前工作目录下的所有文件或目录显示到标准输出,处理为 类似以ls的长格式显示命令执行 # find -ls 819201 4 drwxrwxrwt 8 root root 4096 Jun 12 20:53 . 819205 4 drwxrwxrwt 2 root root 4096 Feb 24 10:59 ./.font-unix 819232 4 -r--r--r-- 1 root root 11 Jul 31 2017 ./.X1-lock .... # ls -a -l -i 以这种格式输出 819201 drwxrwxrwt. 8 root root 4096 Jun 12 20:53 . 2 dr-xr-xr-x. 26 root root 4096 Jun 12 13:29 .. 819205 drwxrwxrwt. 2 root root 4096 Feb 24 10:59 .font-unix 819212 -rw-r--r-- 1 root root 358 Jun 12 17:09 fstab ... 2、指定目录下,以此格式输出 # find /etc -ls .... 540806 4 -rw-r--r-- 1 root root 1982 Dec 22 01:00 /etc/virc 541461 4 -rw-r--r-- 1 root root 767 May 22 21:40 /etc/netconfig 541630 4 -rw-r----- 1 root named 1715 Jul 10 2017 /etc/named.conf 541588 4 -r--r----- 1 root root 3907 Jun 23 2017 /etc/sudoers
-delete 删除查找到的文件
1、确认当前目录有哪些文件 # ls -a . .. .font-unix fstab .ICE-unix test .Test-unix .X11-unix .X1-lock .XIM-unix 2、默认路径为当前目录,操作为-delete # find -delete # echo $? #命令执行状态结果 0 3、显示当前目录的文件(./表示当前目录, ../表示上一级目录 # find ./ ./ #已经删除
-fls /PATH/TO/SOMEFILE查找到的文件的长格式信息保存至指定的文件中
1、准备文件 # install -m 640 /etc/{fstab,issue,ntp.conf,rc.d/init.d/functions,rc.d/rc.sysinit} /tmp 2、确保文件存在 # find -ls 819201 4 drwxrwxrwt 2 root root 4096 Jun 12 21:30 . 819205 4 -rw-r----- 1 root root 23 Jun 12 21:30 ./issue 819206 4 -rw-r----- 1 root root 2439 Jun 12 21:30 ./ntp.conf 819212 24 -rw-r----- 1 root root 20611 Jun 12 21:30 ./rc.sysinit 819204 4 -rw-r----- 1 root root 358 Jun 12 21:30 ./fstab 819207 16 -rw-r----- 1 root root 15131 Jun 12 21:30 ./functions 3、查找到的文件的长格式信息保存至指定的文件中 # find /tmp -fls /tmp/fls.out [[email protected] tmp]# cat /tmp/fls.out ##由以上查找结果和下对比 819201 4 drwxrwxrwt 2 root root 4096 Jun 12 21:33 /tmp 819205 4 -rw-r----- 1 root root 23 Jun 12 21:30 /tmp/issue 819206 4 -rw-r----- 1 root root 2439 Jun 12 21:30 /tmp/ntp.conf 819212 24 -rw-r----- 1 root root 20611 Jun 12 21:30 /tmp/rc.sysinit 819204 4 -rw-r----- 1 root root 358 Jun 12 21:30 /tmp/fstab 819217 0 -rw-r--r-- 1 root root 0 Jun 12 21:33 /tmp/fls.out 819207 16 -rw-r----- 1 root root 15131 Jun 12 21:30 /tmp/functions
-ok COMMAND 查找到的每个文件将交互式的执行由COMMAND指定的命令
1、查找的文件 # find /tmp /tmp /tmp/issue /tmp/ntp.conf /tmp/rc.sysinit /tmp/fstab /tmp/fls.out /tmp/functions 2、交互式的执行命令 # find /tmp -ok ls -l {} \; < ls ... /tmp > ? y total 56 -rw-r--r-- 1 root root 554 Jun 12 21:33 fls.out -rw-r----- 1 root root 358 Jun 12 21:30 fstab -rw-r----- 1 root root 15131 Jun 12 21:30 functions -rw-r----- 1 root root 23 Jun 12 21:30 issue -rw-r----- 1 root root 2439 Jun 12 21:30 ntp.conf -rw-r----- 1 root root 20611 Jun 12 21:30 rc.sysinit < ls ... /tmp/issue > ? y -rw-r----- 1 root root 23 Jun 12 21:30 /tmp/issue < ls ... /tmp/ntp.conf > ? y -rw-r----- 1 root root 2439 Jun 12 21:30 /tmp/ntp.conf < ls ... /tmp/rc.sysinit > ? y -rw-r----- 1 root root 20611 Jun 12 21:30 /tmp/rc.sysinit < ls ... /tmp/fstab > ? y -rw-r----- 1 root root 358 Jun 12 21:30 /tmp/fstab < ls ... /tmp/fls.out > ? n < ls ... /tmp/functions > ? n
-exec COMMAND {} \; 查找到的每个文件直接执行由COMMAND指定的命令
1、查找文件 # find /tmp -ls 819201 4 drwxrwxrwt 2 root myuser 4096 Jun 12 21:33 /tmp 819205 4 -rw-r----- 1 root root 23 Jun 12 21:30 /tmp/issue 819206 4 -rw-r----- 1 root root 2439 Jun 12 21:30 /tmp/ntp.conf 819212 24 -rw-r----- 1 root root 20611 Jun 12 21:30 /tmp/rc.sysinit 819204 4 -rw-r----- 1 root root 358 Jun 12 21:30 /tmp/fstab 819217 4 -rw-r--r-- 1 root root 554 Jun 12 21:33 /tmp/fls.out 819207 16 -rw-r----- 1 root root 15131 Jun 12 21:30 /tmp/functions 2、修改属主 # useradd myuser # find /tmp -exec chown myuser {} \; # find /tmp -ls 819201 4 drwxrwxrwt 2 myuser myuser 4096 Jun 12 21:33 /tmp 819205 4 -rw-r----- 1 myuser root 23 Jun 12 21:30 /tmp/issue 819206 4 -rw-r----- 1 myuser root 2439 Jun 12 21:30 /tmp/ntp.conf 819212 24 -rw-r----- 1 myuser root 20611 Jun 12 21:30 /tmp/rc.sysinit 819204 4 -rw-r----- 1 myuser root 358 Jun 12 21:30 /tmp/fstab 819217 4 -rw-r--r-- 1 myuser root 554 Jun 12 21:33 /tmp/fls.out 819207 16 -rw-r----- 1 myuser root 15131 Jun 12 21:30 /tmp/functions
大量参数袭来,使用xargs命令
1、显示 [[email protected] tmp]# find /tmp | xargs ls -l -rw-r--r-- 1 myuser root 554 Jun 12 21:33 /tmp/fls.out -rw-r----- 1 myuser root 358 Jun 12 21:30 /tmp/fstab -rw-r----- 1 myuser root 15131 Jun 12 21:30 /tmp/functions -rw-r----- 1 myuser root 23 Jun 12 21:30 /tmp/issue -rw-r----- 1 myuser root 2439 Jun 12 21:30 /tmp/ntp.conf -rw-r----- 1 myuser root 20611 Jun 12 21:30 /tmp/rc.sysinit /tmp: total 56 -rw-r--r-- 1 myuser root 554 Jun 12 21:33 fls.out -rw-r----- 1 myuser root 358 Jun 12 21:30 fstab -rw-r----- 1 myuser root 15131 Jun 12 21:30 functions -rw-r----- 1 myuser root 23 Jun 12 21:30 issue -rw-r----- 1 myuser root 2439 Jun 12 21:30 ntp.conf -rw-r----- 1 myuser root 20611 Jun 12 21:30 rc.sysinit 2、改变属主 [[email protected] tmp]# find /tmp | xargs -I {} chown root {} [[email protected] tmp]# ls -l total 56 -rw-r--r-- 1 root root 554 Jun 12 21:33 fls.out -rw-r----- 1 root root 358 Jun 12 21:30 fstab -rw-r----- 1 root root 15131 Jun 12 21:30 functions -rw-r----- 1 root root 23 Jun 12 21:30 issue -rw-r----- 1 root root 2439 Jun 12 21:30 ntp.conf -rw-r----- 1 root root 20611 Jun 12 21:30 rc.sysinit
二、查找条件
按文件名查找
-name "文件名称" 严格区分文件名大小写,文件名支持glob ? * [] [^] 字符集
-iname "文件名称" 查找时不区分大小写
-regex "PATTERN" 正则表达式 regular expression ,支持部分
-iregex
-name "文件名称" 严格区分文件名大小写,文件名支持glob通配符 ? * [] [^] 字符集
[[email protected] ~]# find /etc -name "passwd" /etc/pam.d/passwd /etc/passwd [[email protected] ~]# find /etc -name "*passwd" /etc/pam.d/passwd /etc/passwd /etc/security/opasswd [[email protected] ~]# find /etc -name "passwd*" /etc/passwd- /etc/pam.d/passwd /etc/passwd
-iname "文件名称" 文件名称中给出的字符不区分大小写,LInux文件名严格区分大小写
1、准备区分大小写的文件名称 [[email protected] ~]# touch /tmp/{file1,File1,FILE1} [[email protected] ~]# ls /tmp/{file1,File1,FILE1} /tmp/file1 /tmp/File1 /tmp/FILE1 2、文件名称中给出的字符不区分大小写 [[email protected] ~]# find /tmp -iname "file*" #不区分 /tmp/File1 /tmp/file1 /tmp/FILE1 [[email protected] ~]# find /tmp -name "file*" /tmp/file1
-regex "PATTERN" 正则表达式 regular expression . [] [^] * \+ \? \{m,n\} ()
[[email protected] ~]# find /tmp -regex "[[:alnum:]]\+$" ##没有匹配到,或许对正则表达式支持不太好。 [[email protected] ~]# echo $? 0 [[email protected] ~]# [[email protected] ~]# find /tmp -regex ".*[Ff]..[eE]1" /tmp/File1 /tmp/file1 /tmp/FILE1 [[email protected] ~]# find /tmp -iregex ".*file1" ##忽略字字符大小写 /tmp/File1 /tmp/file1 /tmp/FILE1
属主和属组查找
-user USERNAME 查找属主为 指定用户的文件
-group GROUP 查找属组为 指定组的文件
-uid UID 查找属主为指定的UID文件
-gid GROUPID 查找属组为指定的GROUPID文件
-nouser 查找 没有属主的文件。只有id号,属于用户的文件,在用户被删除后,文件只有ID号
-nogroup 查找 没有属组的文件
-user USERNAME 查找属主为 指定用户的文件
1、将file1,File1,FILE1文件的属主改为myuser [[email protected] ~]# find /tmp -iname "file1" -exec chown myuser {} \; [[email protected] ~]# find /tmp -iname "file1" -ls 819226 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/FILE1 2、查找属主为Myser的文件 [[email protected] ~]# find /tmp -user myuser /tmp/File1 /tmp/file1 /tmp/FILE1
-group GROUP 查找属组为 指定组的文件
1、准备 [[email protected] ~]# useradd centos ##添加centos用户 [[email protected] ~]# su - centos ##切换至centos用户 [[email protected] ~]$ cp /etc/fstab /tmp ##cp进程的属主为centos,创建的文件也属于centos [[email protected] ~]$ cp /var/log/wtmp /tmp [[email protected] ~]$ ls -l /tmp/wtmp /tmp/fstab -rw-r--r-- 1 centos centos 358 Jun 12 22:53 /tmp/fstab -rw-rw-r-- 1 centos centos 13056 Jun 12 22:54 /tmp/wtmp [[email protected] ~]$ exit logout [[email protected] ~]# 2、修改属主为root [[email protected] ~]# find /tmp -group centos -exec chown root {} \; 3、查看/tmp之下的属组为centos的文件 [[email protected] ~]# find /tmp -group centos -ls 819228 4 -rw-r--r-- 1 root centos 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 root centos 13056 Jun 12 22:54 /tmp/wtmp [[email protected] ~]# find /tmp -group centos -ls 819228 4 -rw-r--r-- 1 centos centos 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 centos centos 13056 Jun 12 22:54 /tmp/wtmp
-uid UID 查找属主为指定的UID文件
1、获取myuser的UID [[email protected] ~]# id myuser uid=10003(myuser) gid=10009(myuser) groups=10009(myuser) 2、按此id查找文件 [[email protected] ~]# find /tmp -uid 10003 -ls 819226 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 /tmp/FILE1
-gid GROUPID 查找属组为指定的GROUPID文件
1、获取centos用户的GID [[email protected] ~]# id centos uid=10004(centos) gid=10010(centos) groups=10010(centos) 2、按组id查找 [[email protected] ~]# find /tmp -gid 10010 -ls 819228 4 -rw-r--r-- 1 root centos 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 root centos 13056 Jun 12 22:54 /tmp/wtmp
-nouser 查找 没有属主的文件。只有id号
1、查看属主不是root的文件 [[email protected] ~]# ls -l /tmp total 76 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 file1 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 File1 -rw-r--r-- 1 myuser root 0 Jun 12 22:31 FILE1 2、确认为myuser用户,删除用户生成没有属主的文件 [[email protected] ~]# userdel -r myuser [[email protected] ~]# ls -l /tmp total 76 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 file1 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 File1 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 FILE1 3、查找 [[email protected] ~]# find /tmp -nouser -ls 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1
-nogroup 查找 没有属组的文件
1、查看属组不是root的文件 [[email protected] ~]# ls -l /tmp -rw-r--r-- 1 root centos 358 Jun 12 22:53 fstab -rw-rw-r-- 1 root centos 13056 Jun 12 22:54 wtmp 2、确认为myuser用户,删除用户生成没有属主的文件 [[email protected] ~]# userdel -r centos [[email protected] ~]# ls -l /tmp -rw-r--r-- 1 root 10010 358 Jun 12 22:53 fstab -rw-rw-r-- 1 root 10010 13056 Jun 12 22:54 wtmp 3、查找 [[email protected] ~]# find /tmp -nogroup -ls 819201 4 drwxrwxrwt 2 root 10009 4096 Jun 12 22:54 /tmp 819228 4 -rw-r--r-- 1 root 10010 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 root 10010 13056 Jun 12 22:54 /tmp/wtmp
根据文件类型查找
-type TYPE
TYPE:
f 普通文件
d 目录 文件
b 块设备文件
c 字符设备文件
l 符号链接文件
p 管道文件
s 套接字文件
1、查找/etc/目录下为目录的文件 [[email protected] ~]# find /etc -type d ... /etc/python /etc/statetab.d /etc/openldap /etc/openldap/certs /etc/openldap/schema 2、查找/下为套接字的文件 [[email protected] ~]# find / -type s -ls ... 6767 0 srw-rw-rw- 1 root root 0 Jul 31 2017 /run/systemd/journal/stdout 6751 0 srwx------ 1 root root 0 Jul 31 2017 /run/systemd/cgroups-agent 6749 0 srwxrwxrwx 1 root root 0 Jul 31 2017 /run/systemd/notify 3、查找/tmp为普通文件的文件 [[email protected] ~]# find /tmp -type f -ls 819217 4 -rw-r--r-- 1 root root 554 Jun 12 21:33 /tmp/fls.out.new.new 819206 4 -rw-r----- 1 root root 2439 Jun 12 21:30 /tmp/ntp.conf.new.new 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1
组合条件
与 -a
或 -o
非 ! 或 -not
摩根定律
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)
1、没有属主或没有属组的文件 1)/tmp下没有属主的文件 [[email protected] ~]# find /tmp -nouser -ls 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1 2)没有属组的文件 [[email protected] ~]# find /tmp -nogroup -ls 819201 4 drwxrwxrwt 2 root 10009 4096 Jun 12 22:54 /tmp 819228 4 -rw-r--r-- 1 root 10010 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 root 10010 13056 Jun 12 22:54 /tmp/wtmp 3)组合 [[email protected] ~]# find /tmp -nogroup -o -nouser ##正解 /tmp /tmp/File1 /tmp/file1 /tmp/fstab /tmp/wtmp /tmp/FILE1 [[email protected] ~]# find /tmp -nogroup -o -nouser -ls ###有问题 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1 #############组合条件中,-ls仅显示靠近ls的条件所匹配的内容############# [[email protected] ~]# find /tmp \( -nogroup -o -nouser \) -ls ##正解 819201 4 drwxrwxrwt 2 root 10009 4096 Jun 12 22:54 /tmp 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819228 4 -rw-r--r-- 1 root 10010 358 Jun 12 22:53 /tmp/fstab 819232 16 -rw-rw-r-- 1 root 10010 13056 Jun 12 22:54 /tmp/wtmp 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1 ## \( \) 仅为了方便显示 2)tmp下owner不是root且文件名不是fstab [[email protected] ~]# find /tmp -not -user root -a -not -name "fstab" /tmp/File1 /tmp/file1 /tmp/FILE1 [[email protected] ~]# find /tmp \( -not -user root -a -not -name "fstab" \) -ls 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1 [email protected] ~]# find /tmp -not \( -user root -o -name "fstab" \) -ls 819226 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/File1 819218 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/file1 819227 0 -rw-r--r-- 1 10003 root 0 Jun 12 22:31 /tmp/FILE1
根据文件大小来查找
-size [+|-]#UNIT
UNIT: K M G
-size -#UNIT [0,#-1]
-size #UNIT (#-1,#]
-size +#UNIT (#,+oo]
1、文件大小等于3k的文件 (2,3] [[email protected] ~]# find /var -size 3k -exec ls -lh {} \; .... -rw-r--r-- 1 root root 2.9K Jul 24 2017 /var/lib/docker/volumes/1c198521fea9eb05afa8605bb9be3c5651a1be303d3b7d06f0a74302e5f2217a/_data/cphalcon/build/_resource/Phalcon/Build/Generator/Safe.php -rw-r--r-- 1 root root 2.2K Jul 24 2017 /var/lib/docker/volumes/1c198521fea9eb05afa8605bb9be3c5651a1be303d3b7d06f0a74302e5f2217a/_data/cphalcon/build/php7/64bits/build/mkdep.awk -rw-r--r-- 1 root root 2.2K Jul 24 2017 /var/lib/docker/volumes/1c198521fea9eb05afa8605bb9be3c5651a1be303d3b7d06f0a74302e5f2217a/_data/cphalcon/build/php7/64bits/config.h -rw-rw---- 1 102 105 3.0K Jun 5 11:01 /var/lib/docker/volumes/820559fb16372047d77b04198c7acb2558d28a2e5dba2a552fafe752c51e2657/_data/mysql/help_category.MYI -rw-rw---- 1 102 105 3.0K Jun 28 2017 /var/lib/docker/volumes/d5a21db1e5e6cc3156c1b65df2c02c2f621a04624dfbfe0b43f985a001a7621b/_data/mysql/help_category.MYI -rw-rw---- 1 102 105 3.0K Jun 28 2017 /var/lib/docker/volumes/78877a432184402ad398d087e11c60327518a8aa33837d2d33d5a65965b25e2a/_data/mysql/help_category.MYI -rw-rw-rw- 1 root root 2.3K Jul 24 2017 /var/lib/docker/containers/1d72cfe7c1a3334018d24c835abba40a3304ea80c10b5f77870f9fea3d16235d/config.v2.json -rw-r--r-- 1 root root 2.2K Jun 14 2017 /var/lib/pcsd/pcs_users.conf ...... 2、文件大小 小于3k的文件 [0,2] [[email protected] ~]# find /var -size -3k -exec ls -lh {} \; 30873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/etc/inittab -rw-r--r-- 1 root root 295 Dec 14 2015 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/etc/profile.d/color_prompt -rw-r--r-- 1 root root 42 Dec 14 2015 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/etc/hosts -rw-r--r-- 1 root root 10 Dec 14 2015 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/etc/hostname -rw-r--r-- 1 root root 65 Dec 16 2015 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/etc/securetty -rw-r--r-- 1 root root 1.2K Jan 14 2016 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/usr/share/ca-certificates/mozilla/Sonera_Class_2_Root_CA.crt -rw-r--r-- 1 root root 1.3K Jan 14 2016 /var/lib/docker/volumes/4e61477adc56ecfceb1f629130873eee5c6a71770e65619fac9686fd3e434c63/_data/vfs/dir/27fecbb711f7d6f520a4e32051645fe2b8aafb4406215e46d2b1c7cdadb8e597/usr/share/ca-certificates/mozilla/Deutsche_Tele 3、文件大小 大于3k的文件 (3,+oo) drwxr-xr-x 2 root root 4.0K Jun 6 11:22 02ae32a463293daba05d702b0c157beac3b62da3-samba-common-libs-4.4.4-14.el7_3-x86_64 drwxr-xr-x 2 root root 4.0K Jul 31 2017 07c18fc8a3449cf6abc357860ebcca7121ef410c-selinux-policy-3.13.1-102.el7_3.16-noarch drwxr-xr-x 2 root root 4.0K May 18 17:56 0c9550ff7f47e27a0bce727be65f5ecbccaffa37-screen-4.1.0-0.23.20120314git3c2946.el7_2-x86_64 drwxr-xr-x 2 root root 4.0K Feb 24 03:08 13fd3e30a775cdc312d449d9880a34d470a04f88-systemtap-runtime-3.0-7.el7-x86_64 drwxr-xr-x 2 root root 4.0K Jul 31
天
-atime [+|-]# 访问时间
-atime -3 [0,3) 距离现在小于3天
-atime 3 [3,4) 距离现在有3天
-atime +3 [4,+oo] 距离现在大于3天
-mtime [+|-]# 修改时间
-mtime -3 [0,3) 距离现在小于3天
-mtime 3 [3,4) 距离现在有3天
-mtime +3 [4,+oo] 距离现在大于3天
-ctime [+|-]# 改变时间
-ctime -3 [0,3) 距离现在小于3天
-ctime 3 [3,4) 距离现在有3天
-ctime +3 [4,+oo] 距离现在大于3天
分钟
-amin [+|-]#
-mmin [+|-]#
-cmin [+|-]#
1、准备3个文件 [[email protected] tmp]# touch a b c [[email protected] tmp]# ll total 0 -rw-r--r-- 1 root root 0 Aug 4 19:49 a -rw-r--r-- 1 root root 0 Aug 4 19:49 b -rw-r--r-- 1 root root 0 Aug 4 19:49 c 2、修改a为距离现在有3天 [[email protected] tmp]# touch -a -t 201708011700.00 a [[email protected] tmp]# stat a Access: 2017-08-01 17:00:00.000000000 +0800 Modify: 2017-08-04 19:49:55.910297650 +0800 Change: 2017-08-04 19:51:57.971293624 +0800 3、修改b为距离现在小于3天 [[email protected] tmp]# touch -a -t 201708012000.00 c [[email protected] tmp]# stat c Access: 2017-08-01 20:00:00.000000000 +0800 Modify: 2017-08-04 19:49:55.910297650 +0800 Change: 2017-08-04 19:52:40.346292227 +0800 4、修改c为距离现在大于3天 [[email protected] tmp]# touch -a -t 201707311930.00 b [[email protected] tmp]# stat b Access: 2017-07-31 19:30:00.000000000 +0800 Modify: 2017-08-04 19:49:55.910297650 +0800 Change: 2017-08-04 19:57:06.459283447 +0800 搜索/tmp下访问距离现在有3天 [[email protected] tmp]# find /tmp -atime 3 /tmp/a 搜索/tmp下访问距离现在小于3天 [[email protected] tmp]# touch -a -t 201708012000.00 c [[email protected] tmp]# find /tmp -atime -3 /tmp/c 搜索/tmp下访问距离现在大于3天 [[email protected] tmp]# find /tmp -atime +3 /tmp/b
根据权限查找
-perm [/|-]MODE
# find /etc -perm /MODE 某类用户的某位权限匹配,即可 或
# fine /etc -perm -MODE 权限至少为MODE权限
# find /etc -perm MODE 权限必须为由MODE指定的权限
1、权限必须为由MODE指定的权限
[[email protected] tmp]# find /etc -perm 000 -ls 541665 4 ---------- 1 root root 1399 Jun 12 23:04 /etc/gshadow 540719 4 ---------- 1 root root 2895 Jun 12 23:04 /etc/shadow- 541797 4 ---------- 1 root root 2866 Jun 12 23:04 /etc/shadow 540711 4 ---------- 1 root root 1410 Jun 12 23:04 /etc/gshadow-
2、权限至少为MODE权限
540724 660 -rw-r--r-- 1 root root 670293 Jun 7 2013 /etc/services 540806 4 -rw-r--r-- 1 root root 1982 Dec 22 2016 /etc/virc 541461 4 -rw-r--r-- 1 root root 767 May 22 21:40 /etc/netconfig 541630 4 -rw-r----- 1 root named 1715 Jul 10 13:58 /etc/named.conf 541588 4 -r--r----- 1 root root 3907 Jun 23 03:42 /etc/sudoers [[email protected] tmp]# find /etc -perm -400 -ls #也就是属主的权限,至少有r权限 540874 0 lrwxrwxrwx 1 root root 56 Feb 24 10:59 /etc/favicon.png -> /usr/share/icons/hicolor/16x16/apps/fedora-logo-icon.png 541531 0 lrwxrwxrwx 1 root root 35 Jun 14 16:17 /etc/cifs-utils/idmap-plugin -> /etc/alternatives/cifs-idmap-plugin [[email protected] tmp]# find /etc -perm -422 -ls # 属主至少4,属组至少2,其他至少2
3、某类用户的某位权限匹配,即可
541488 24 -rw-r--r-- 1 root root 22900 May 25 19:33 /etc/openldap/schema/samba.schema 540724 660 -rw-r--r-- 属主r或w匹配 540806 4 -rw-r--r-- 属主r或w匹配 541461 4 -rw-r--r-- 属主r或w匹配 541630 4 -rw-r----- 属主r或w匹配 541588 4 -r--r----- 属主r匹配 [[email protected] tmp]# find /etc -perm /422 -ls
本文出自 “Reading” 博客,请务必保留此出处http://sonlich.blog.51cto.com/12825953/1953698
以上是关于谢烟客---------Linux之find查找的主要内容,如果未能解决你的问题,请参考以下文章