文件查找:
locate:
非实时,查找是根据全系统文件数据库运行的;
updatedb ,手动生成文件数据库
速度快
find:
实时
精确
支持众多查找标准
遍历指定目录中的所有文件完成查找,速度慢
Usage:
find查找路径,查找标准,查找到以后的处理运作
查找路径:默认为当前目录
查找标准:默认为指定路径下的所有文件
处理运作:默认为显示
匹配标准:
-name “filename”,对文件名作精确匹配
文件名匹配:
*:
.:
?:
-iname “filename”:对文件名不区分大小写
-regex PATTERN:基于正则表达式进行文件查找(这个用的不多)
-user USERNAME :基于用户名进行查找
-group GROUPNAME:基于属组进行查找
-uid :这个要说明,用户存在的时候可以不用这个,但是当用户删除的时候,他所拥有的文件的拥有者将会变成他原来名称的uid,所以这个价值体现在这;
-gid:根据GID查找
-nouser:查找没有属主的文件(这个挺重要)
-nogroup:查找没有属组的文件
-type:根据文件类型进行查找
f:普通文件
d:目录
c:字符设备
b:块设备
l:链接
p:管道设备
s:套接字
-size:根据文件大小今次那个查找
[+:大于/ -:小于]k:
M:
G:
说明,在进行精确查找时,1M意味着按一定规则的都认为是1M;;
组合条件:
-a 与
-o 或
-not 非
find /tmp -not -user root
find /tmp -user root -o -user geasyheart
find /tmp -not user1 -a -not user2
find ./ -not (-user user1 -a -type d)
-mtime:修改时间
-ctime:改变时间
-atime:访问时间
[+,-]:+5至少5天没访问过 -5:最近5天访问过
-mmin
-cmin
-amin:分钟;;;
然后可以使用stat + 文件名进行查看这个文件的信息
根据文件权限进行查找:
-perm mode 每一位权限必须精确匹配
-perm -mode 文件包含的权限包含查找的权限就可匹配出来
-perm /mode 只要有一位就可以
find ./ -perm 644
find ./ -perm /011 组或其他user具有执行权限
find ./ -perm -011 组和其他user具有执行权限
运作:
-print:显示
-ls:类似ls -l 的形式显示每一个文件的详细信息
-ok COMMAND {} ;每一步都需要用户确认
-exec COMMAND () ;
find -perm -006 –exec chmod o-w {} ;
find ./ -perm -020 –exec mv {} {}.new ;
(!!!所以,{}的意思是指匹配到的的集合!!!)
练习:
- 查找/var目录下属主为root并且数组为mail的所有文件;
find /var -user root -a -group mail
- 查找/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 ) - 查找/etc目录下最近一周内内容修改过且不属于root及student用户的文件;
find /etc –mtime -7 -a ( - not -user root -a -not -user student )
- 查找当前系统上没有属主或属组且最近1天内曾经访问过的文件,并将其属主属组均修改为root
find / (-nouser -o -nogroup) -a -atime -1 -exec chmod root:root {} ;
- 查找/etc目录下大于1M的文件,并将其文件名写入到/tmp/etc.largefiles文件中
find /etc -size +1M >> /tmp/etc.largefiles
find /etc -size +1M | xargs echo >> /tmp/etc.largefiles - 查找/etc目录下所有用户都没有写权限的文件,显示出其详细信息
find /etc -not -perm /222 -ls