文件查找
小编在学这堂课的前一天夜里打嗝打了半宿,第二天上课的时候迷迷糊糊,所以,导致文件查找这章我放了好久的鸽子。
这里是回看视频摘出来的笔记。如有理解有偏差,请留言。
本篇只有3个命令,重点是find,时间有限的朋友可以只看find命令。这太过重要了。
whereis命令
在一些特定的目录搜索,搜索二进制文件、帮助文件、源文件等
选项:
不加任何选项就会列出所有文件。
-b 只搜索二进制文件
-m 只搜索帮助文件
-s 只搜索源文件
-l 列出whereis搜索的路径,也就是whereis会在这些路径下搜索内容
-u 不是上述三类文件的其它类型文件。
locate命令
用来快速搜索文件的工具,是根据索引数据库搜索的。数据路位置/var/lib/mlocate/mlocate.db
1、新系统可能没有这个数据库,updatedb命令可以手工更新数据库
2、updatedb这个命令会消耗大量的IO 需要在系统不繁忙的时候更新
3、updatedb命令会根据/etc/updatedb.conf的设定取搜索硬盘内的文件名,并保存在/var/lib/mlocate目录下的数据库内。
locate命令 主要用来搜索静态文件
-i 不区分大小写搜索
-r 使用基本正则表达式
-b 只搜索文件名,而不搜索全路径。默认是搜索全路径
-c 计数
-n # 只显示前几个搜索结果
-S 显示locate数据库信息
备注:
locate不能指定文件搜索路径,要想指定搜索路径需要手工使用正则表达式指定,祥看示例
locate不是实时搜索,而且是模糊搜索
locate默认会搜索文件的全路径,不仅仅是文件名,意思是如果目录包含某个关键词,目录下的所有文件都会被搜索到
locate只会搜索当前用户能访问到的目录,意思是如果某个用户对某个目录没有访问权限,该目录就不会被搜索
示例说明:指定搜索路径{
[root@CentOS7 scripts]#locate -r "^/data/scripts/.*\.sh"
/data/scripts/FOOT.sh
/data/scripts/adddescrption.sh
/data/scripts/arg.sh
/data/scripts/arg2.sh
/data/scripts/argsnum.sh
/data/scripts/backup_etc.sh
/data/scripts/bim.sh
/data/scripts/checkdisk.sh
/data/scripts/checkint.sh
/data/scripts/createuser.sh
/data/scripts/df_warning.sh}
find命令
实时查找,精确查找,查找条件丰富,只搜索具有权限的目录
find [OPTIONS] [查找路径] [查找条件] [处理动作]
默认是递归搜索,默认是搜索当前目录
选项:
-maxdepth # 最大搜索深度,指定搜索目录下搜索到第几级
-mindepth # 最小搜索深度,
-depth或-d 一般是先搜索文件夹,再去搜索文件夹内的文件。如果加上该选项-d,就会先搜索文件,在搜索目录
查找条件:
根据文件名搜索
-name 文件名 根据文件名搜索,精确匹配而不是模糊搜索。支持通配符
如果想要模糊搜索,可以使用 "*文件名*" 建议在使用通配符的时候要加上双引号,要不会产生各种莫名奇妙的问题
-iname 文件名 不区分大小写搜索
-inum INODE 根据INODE节点号搜索,可以用来搜索硬链接
-samefile 文 件名 搜索相同节点编号的文件,需要注意的是,需要搜索同一分区内的相同节点编号
-links # 根据链接数为#这个条件进行搜索
-regex "PATTERN" 以PATTERN匹配整个文件路径,而非文件名称
根据属性信息搜索
-user 用户名 根据所有者搜索
-group 组名 根据所属组搜索
-nouser 用户名 搜索没有所有者的文件
-nogroup 组名 搜索没有所属组的文件
-uid UID 根据UID查找
-gid GID 根据GID查找
根据文件类型搜索
-type TYPE 根据文件类型搜索
TYPE:
d 查找文件类型为目录的所有文件
f 查找文件类型为普通文件的所有文件
p 查找文件类型为管道文件的所有文件
s 查找文件类型为套接字的所有文件
c 查找文件类型为字符设备的所有文件
b 查找文件类型为块设备的所有文件
l 查找文件类型为软连接的所有文件
搜索空文件或目录
-empty 搜索空文件或者文件夹
组合条件
-a 与 默认就是按照并且条件搜索多个条件
-o 或
-not|! 非
因为与的优先级高于或的优先级,可以使用()扩起或的选项以提高或的优先级,()需要转义写成\( \)
德*摩根定律:
(非A)或(非B)=非(A且B)
(非A)且(非B)=非(A或B)
排除特定目录搜索
-path 排除文件夹路径 -a -prune -o -name 文件名 指定不搜那些文件夹
例:
find / \( -path "/sys" -o -path "/proc"\) -a -prune -o -name "*.conf"
# 搜索除/proc和/sys目录以外的所有路径下的以.conf结尾的文件
find / \( -path "/sys" -o -path "/proc" \) -a -prune -o -name "*.conf"
根据文件大小搜索
-size [+|-] #UNIT
常用单位k M G c(byte) 注意大小写
6k 表示 (5k,6k],包括6K不包括5K
-6k 表示 [0k,6-1k],包括0k也包括5k,两个之间
+6k 表示(6K,oo),不包含6k
-size 1024k和-size 1M的区别
-size 1024k 会搜索到1023k到1024k之间的文件
-size 1M 会搜索到0到1M之间的文件
根据时间戳查找
-atime [+|-]#
+10 表示11天以前的文件
-1 表示最近一天内的文件
10 表示10天到11天内,
-mtime [+|-]#
-ctime [+|-]#
-mmin [+|-]# 表示按分钟搜索
-amin [+|-]#
-cmin [+|-]#
根据权限搜索
-perm [/|-] MODE
MODE:精确权限匹配
/MODE 任何一类(u g o)对象的任何一位权限(r w x)中,只要能匹配一位权限就能搜索到,是或的关系
-MODE 表示任何一类(u g o)对象的权限中r w x三者都完满条件才匹配,是并且的关系
如果MODE中三类对象中有一位是0,表示对应该类对象无论有没有权限无所谓
备注,在centos7后,+的写法开始淘汰,使用/代替了
find -perm 755 会精确搜索权限是755的文件
find -perm /222 只要任何一类用户有写权限就会匹配。或者说,至少有一类用户有写权限就会匹配
find -perm /111 只要任何一类用户有写权限的就会匹配。或者说,至少有一类用户有执行权限就会匹配
find -perm /666 只要任何一类用户有读或者有写权限就会匹配。
find -perm /001 其他用户有执行权限的文件才会匹配
find -perm /002 其他用户有写权限的文件才会匹配
find -perm -222 只有当文件的所有者、所属组、其他人三类用户都有写权限才会匹配
find -perm -002 只要其它人具有写权限就会匹配,和find -perm /002的作用相同
find -perm -022 所属组和其他人都具有写权限就会匹配
find -perm 002 只匹配 --- --- -w-权限的文件
处理动作
-print 默认,会把搜索结果打印屏幕,默认是以空格作为分割符。可以使用pring0选项改成使用nul作为分隔符
-ls 把搜索的文件的详细属性显示出来
-fls /PATH/TO/FILE 查找到的每个文件长格式显示保存至指定文件,相当于 -ls > /PATH/TO/FILE
-delete 把搜索到的文件删除,太危险,慎用
-ok COMMAND {} \; 对查找到的每个文件交由COMMAND指定的命令执行,但是在执行前会交互式提问
-exec COMMAND {} \; 对超找到的每个文件交由COMMAND指定的命令执行,不会交互提问直接执行
{} 指的是find搜索的的文件,可以想成一个变量,此变量引用find搜索到的文件
\; 交由COMMAND执行 必须要有\;结束
find /data -exe rm {} \ 删除搜索到的文件
find /var -size +10M -mtime +10 -ok mv {} /data \ 把在VAR下搜索到的大于10M时间超过10天之前的文件移动到data目录下
find /data -name "*.txt" -exec cp {} {}.bak \; 批量加后缀。注意双{}的使用
小技巧:利用find 和 mv 组合批量加后缀名:
[root@CentOS7 tmp]# ll total 0 -rw-r--r-- 1 root root 0 May 3 05:40 a -rw-r--r-- 1 root root 0 May 3 05:40 b -rw-rw-rw- 1 root root 0 May 3 05:40 c -rw-r--r-- 1 root root 0 May 3 05:40 d -rw-r--r-- 1 root root 0 May 3 05:40 e -r-------- 1 root root 0 May 3 05:40 f -rw-r--r-- 1 root root 0 May 3 05:40 g [root@CentOS7 tmp]# find . -type f -exec mv {} {}.haha \; #小技巧利用find和mv组合批量加后缀名 [root@CentOS7 tmp]# ll total 0 -rw-r--r-- 1 root root 0 May 3 05:40 a.haha -rw-r--r-- 1 root root 0 May 3 05:40 b.haha -rw-rw-rw- 1 root root 0 May 3 05:40 c.haha -rw-r--r-- 1 root root 0 May 3 05:40 d.haha -rw-r--r-- 1 root root 0 May 3 05:40 e.haha -r-------- 1 root root 0 May 3 05:40 f.haha -rw-r--r-- 1 root root 0 May 3 05:40 g.haha [root@CentOS7 tmp]#
练习:
1、查找/var目录下属主为root,且属组为mail的所有文件或目录;
find /var -user root -a -group mail -ls
2、查找/usr目录下不属于root,bin或hadoop的所有文件或目录;用两种方法;
find /usr -not \( -user root -o -user bin -o -user hadoop \) -ls
find /user -not -user root -a -not -user bin -a -not -user hadoop -ls
3、查找/etc目录下最近一周内其内容修改过,且属主不是root用户也不是hadoop用户的文件或目录;
find /etc -mtime -7 -a -not -user root -a -not -user hadoop -ls
find /etc -mtime -7 -a -not \( -user root -o -user hadoop \) -ls
4、查找当前系统上没有属主或属组,且最近一周内曾被访问过的文件或目录;
find \( -nouser -o -nogroup \) -a -atime -7 -ls
5、查找/etc目录下大于1M且类型为普通文件的所有文件;
find /etc/ -size +1M -a -type f -ls
6、查找/etc目录下所有用户都没有写权限的文件;
find /etc -not -perm /222 -type f -ls
7、查找/etc目录至少有一类用户没有执行权限的文件;
find /etc -not -perm -111 -type f -ls
8、查找/etc/init.d/目录下,所有用户都有执行权限,且其它用户有写权限的所有文件;
find /etc/init.d -perm -113 -type f -ls