本篇文章和大家分享一篇Linux命令find的使用教程,全文实操记录、绝无水文,如有遗漏或错误,欢迎各位朋友指正。
find 是 Linux 中强大的搜索命令,不仅可以按照文件名搜索文件,还可以按照权限、大小、时间、inode 号等来搜索文件。但是 find 命令是直接在硬盘中进行搜索的,如果指定的搜索范围过大,find命令就会消耗较大的系统资源,导致服务器压力过大。所以,在使用 find 命令搜索时,不要指定过大的搜索范围。
命令语法:
find path -option [ -print ] [ -exec | -ok command {} \]
path : find命令所查找的目录路径。例如用.来表示当前目录,用/来表示系统根目录。
-print:find命令将匹配的文件输出到标准输出。
-exec:find命令对匹配的文件执行该参数所给出的shell命令。相应命令的形式为’command’ { } ;,注意{ }和;之间的空格。
-ok:和-exec的作用相同,只不过以一种更为安全的模式来执行该参数所给出的shell命令,在执行每一个命令之前,都会给出提示,让用户来确定是否执行。
参数说明:
-amin n :在过去n分钟内被读取过
-anewer file :比文件file更晚被读取过的文件
-atime n :在过去n天内被读取过的文件
-cmin n :在过去n分钟内被修改过
-cnewer file :比文件file更新的文件
-ctime n :在过去n天内被修改过的文件
注:以上+n表示n以前,-n 表示n以内
-empty :空的文件-gid n or -groupname : gid是n或是group名称是name
-ipath p, -path p :路径名称符合p的文件,ipath会忽略大小写
-name name, -iname name :文件名称符合name的文件。iname会忽略大小写
-size n :文件大小是n,单位,b代表512位元组的区块,c表示字元数,k表示kilo bytes。
-type c :文件类型是c的文件。
d:目录
c:字型装置文件
b:区块装置文件
p:具名贮列
f:一般文件
l:符号连结
s: socket
-pid n : process id是n的文件
你可以使用( )将运算式分隔,并使用下列运算。
exp1 -and exp2
! expr
-not expr
exp1 -or exp2
exp1, exp2
实例:
将目前目录及其子目录下所有延伸档名是c的文件列出来。
# find . -name “*.c”
将目前目录其其下子目录中所有一般文件列出
# find . -type f
将目前目录及其子目录下所有最近20天内更新过的文件列出
# find . -ctime -20
查找/var/log目录中更改时间在7日以前的普通文件,并在删除之前询问它们:
# find /var/log -type f -mtime +7 -ok rm {}\;
查找前目录中文件属主具有读、写权限,并且文件所属组的用户和其他用户具有读权限的文件:
# find . -type f -perm 644 -exec ls -l {}\;
为了查找系统中所有文件长度为0的普通文件,并列出它们的完整路径:
# find / -type f -size 0 -exec ls -l {} \;
————————————————
至此关于Linux命令find的分享教程到此结束,欢迎各位朋友在评论区留言。
为各位朋友分享的相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多