Linux查找find命令详解
Linux查找–find命令
首先,大家如果看到有什么不懂的地方,欢迎吐槽!!!
find命令的格式
find pathname -options [ -print -exec -ok ...] pathname #是find命令所查找的目录路径,例如.表示当前目录,/表示根目录 -print #表示find命令将匹配的文件输出到标准输出中 -exec #表示find命令对匹配的文件执行该参数给出的shell命令。相应命令的形式为 ‘cmd’ {} \; -ok #它的作用和-exec一样,只是需要用户交互,更安全
find命令的选项
-name #按照文件名查找文件 -perm #按照权限查找文件 -prune #使find命令不在当前指定的目录中查找,如果同时使用-depth选项,那么-prune将被find命令忽略 -user #按照文件属主来查找文件 -group #按照文件数组来查找文件 -mtime -n +n #按照文件的更改时间来查找文件 -n 表示从此刻算起,文件的更改是在n天以内 +n 表示文件的更改时间是在n天以前 find命令还有-atime和-ctime选项,和-mtime选项的时间规定类 似 -nogroup #查找无有效属组的文件,即该文件所属的组在/etc/groups中不存在 -nouser #查找无有效属主的文件,即该文件的属主在/etc/passwd中不存在 -newer file1 ! file2 #查找更改时间比file1新但比file2旧的文件 -type b:表示块设备文件 block d:表示目录 directory c:表示字符设备文件 char p:表示管道文件 pipe l:表示符号链接文件 link f:表示普通文件 file -depth #在查找文件时,首先查找当前目录中的文件,然后再在其子目录中查找 -fstype #表示查找位于某一类型文件系统中的文件,这些文件系统类型通常可以在配置文件/etc/fstab中找到,该配置文件中包含了本系统中有关文件系统的信息 -mount #表示在查找文件时不跨越文件系统的mount点 -follow #表示如果find命令遇到符号链接文件,就跟踪至链接所指向的文件 -cpio #表示对匹配的文件使用cpio命令,将这些文件备份至磁带设备中
find示例:
1、在logs目录下查找更改时间在5日以前的文件并删除它们 find /logs -mtime +5 -exec rm {} \;
2、在当前目录中查找以.log结尾、更改时间在5日以上的文件,并删除,但在删除前给出提示 find . -name “*.log” -mtime +5 -ok rm {} \;
3、先用find命令匹配所有文件名为”passwd*”的文件,然后执行grep看看这些文件中是否存在一个sam的字符串 find / -name "passwd*" -exec grep "sam" {} \;
4、查找当前用户主目录下的所有文件 find ~
5、查找当前目录下644权限的文件 find . -perm 644
6、查找系统当中所有长度为0的普通文件,并列出它们的完整路径 find / -type f -size 0 -exec ls -l {} \;
7、查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前进行提示 find /var/log -type f -mtime +5 -ok rm {} \;
8、查找当前目录中所有属于root组的文件 find . -group root -exec ls -l {} \;
9、find命令将列出目录中访问时间在7日以内且含有数字后缀的admin.log文件 find . -name "admin.log[0-9]*" -atime -7 -exec ls -l {} \;
用xargs来配合find工作
在使用find命令的-exec选项处理匹配到的文件时,find命令将所有匹配到的文件一起传递给exec执行。但有些系统对传递给exec的命令长度是有限制的,这样,在find命令运行几分钟之后,就会出现溢出错误。错误信息通常是”参数列太长”或”参数列溢出”。这就是xargs命令的用户所在,特别是与find命令一起使用 find命令把匹配到的文件传递给xargs命令,而xargs命令每次只获取一部分文件而不是全部,不像-exec选项那样。这样它就可以先处理最先获取的那一部分文件,然后是下一批,并且如此继续下去。
查找root下面的每个文件,然后使用file查看文件的类别 find /root/ -type f | xargs file
查找root下面的777权限的文件,如果找到,都改为644权限 find /root -perm 777 | xargs chmod 644
查找系统中的所有文件,并过滤出文件中带有rmt的文件 find / -type f | xarfs grep rmt grep -rl rmt / #也可以 r代表递归,l代表只列出匹配的文件
更详细强大的find实例
一、使用name选项
1、在当前目录及子目录中查找所有的*.txt文件 find . -name "*.txt"
2、在当前目录及子目录中查找一个大写字母开头的文件 find . -name "[A-Z]*"
3、想在/etc目录中查找文件名以host开头的文件 find /etc -name "host*
4、查找$HOME目录中的文件 find ~
5、想要让系统高负荷运行,从根目录下面查找所有文件 find / -name "*"
6、在当前目录中查找文件名以两个小写字母开头,跟着是两个数字,最后是.txt的文件 find / -name "[a-z][a-z][0-9][0-9].txt"
二、使用perm���项
找出当前文件夹下权限为755的文件 find . -perm 755
三、使用user和mount选项
1、在宿主目录下查找属主为sam的文件 find ~ -user sam | xargs ls -l
2、查找已经删除用户以前的文件 find / -nouser sam
四、按照更改时间或访问时间等查找文件
-:限定更改时间在距今n日以内的文件 +:限定更改时间是在n日以前的文件 1、在根目录下查找更改时间为最近5日的文件 find / -mtime -5 2、在根目录下查找更改时间为3日以前的文件 find / -mtime +3
五、查找比某个文件新或旧的文件
1、查找比/root/a/a文件新的文件 find / -newer /root/a/a 2、查找比wanglei文件新的文件 find / -newer wanglei 在进行系统维护时,我们经常遇到一种情况,即发现磁盘在不停地发生写现象,这时候我们要定位这个正在写的文件,可以选择建立一个文件,比如test,然后用以下命令找出这个频繁写磁盘的文件(最好带上一些限制大小的参数来精确定位) touch new1 touch new2 find / -newer new1 -o -path "/proc" -prune 找出比new1新的文件,由于/proc目录中的文件一直在变化,所以可以排除
六、使用type选项
1、在/etc目录下查找所有的目录 find /etc -type d | xargs file
2、在当前目录下查找除目录以外的所有类型的文件 find /etc ! -type d | xargs file
3、在/etc/目录一下查找所有的符号链接文件 find /etc -type l | xargs file
八、使用size选项
相关推荐
jimeshui 2020-11-13
chenchuang 2020-05-29
ningningmingming 2020-08-14
andylanzhiyong 2020-06-16
咏月东南 2020-06-16
lanyou00 2020-06-06
secondid 2020-06-05
kylinos 2020-03-07
onlykg 2020-05-06
farwang 2020-04-26
applex 2020-04-22
bluecarrot 2020-04-20
csdnyasin 2020-04-11
xushxbigbear微信 2020-02-19
jackadmi 2020-02-19
神龙 2020-02-15
Darklovy 2020-01-12