文件查找命令 locate 和 find 详解

文件查找命令

  • locate
    • 1、locate 简介
    • 2、locate 命令格式
  • find
    • 1、find 简介
    • 2、语法格式
    • 2.1 查找条件
      • 2.1.1 根据文件名查找
      • 2.1.2 根据文件从属关系查找
      • 2.1.3 根据文件的类型查找
      • 2.1.4 组合测试
      • 2.1.5 根据文件的大小查找
      • 2.1.6 根据时间戳查找
      • 2.1.7 根据权限查找:
    • 2.2 处理动作

在文件系统上查找符合条件的文件。常用命令有 locate 和 find ,下面针对于这两个命令进行详细说明。

locate

1、locate 简介

locate 让使用者可以很快速的搜寻档案系统内是否有指定的档案。其方法是先建立一个包括系统内所有档案名称及路径的数据库,之后当寻找时就只需查询这个数据库,而不必实际深入档案系统之中了。在一般的 distribution 之中,数据库的建立都被放在 crontab 中自动执行。

locate 指令和 find 找寻档案的功能类似,但 locate 是透过 update 程序将硬盘中的所有档案和目录资料先建立一个索引数据库,在执行 loacte 时直接找该索引,查询速度会较快,索引数据库一般是由操作系统管理,但也可以直接下达update强迫系统立即修改索引数据库。

locate:依赖于事先构建好的索引库
	1、系统自动实现(周期性任务)
	2、手动更新数据库(updatedb)

locate 工作特性:
	1、查找速度快
	2、模糊查找
	3、非实时查找

2、locate 命令格式

locate  [OPTION]...  PATTERN...
	-b:只匹配路径中的基名
	-c:统计出共有多少个符合条件的文件
	-r:BRE,使用正规运算式 做寻找的条件

注意:索引构建过程需要遍历整个根文件系统,极消耗资源。
示例:
root@LeeMumu:~# locate /etc/sh       # 查找 /etc 下以 sh 开头的文件
/etc/shadow
/etc/shadow-
/etc/shells
root@LeeMumu:~# locate /etc/pas      # 查找 /etc 下以 pas 开头的文件
/etc/passwd
/etc/passwd-

find

1、find 简介

用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时,不设置任何参数,则 find 命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。

find:在指定目录下查找文件
	实时查找工具,通过遍历指定起始路径下文件系统层级结构完成文件查找。
	
find 工作特性:
	1、查找速度略慢
	2、精确查找
	3、实时查找

2、语法格式

find  [OPTIONS]  [查找起始路径]  [查找条件]  [处理动作]

查找起始路径:
	1、指定具体搜索目标起始路径。
	2、默认为当前目录。
查找条件:
	1、指定的查找标准,可以根据文件名、大小、类型、从属关系、权限等等标准进行。
	2、默认为找出指定路径下的所有文件。
处理动作:
	1、对符合查找条件的文件做出的操作,例如删除等操作。
	2、默认为输出至标准输出。

2.1 查找条件

  • 表达式:选项和测试
  • 测试:结果通常为布尔型(“true”, “false”)

2.1.1 根据文件名查找

-name  "pattern"    # 指定字符串作为寻找文件或目录的范本样式
-iname "pattern"    # 此参数的效果和指定“-name”参数类似,但忽略字符大小写的差别
-regex pattern      # 基于正则表达式模式查找文件,匹配是整个路径,而非其名

2.1.2 根据文件从属关系查找

-user USERNAME    # 查找属主指定用户的所有文件
-group GRPNAME    # 查找属组指定组的所有文件
						
-uid UID          # 查找属主指定的UID的所有文件
-gid GID          # 查找属组指定的GID的所有文件
						
-nouser           # 查找没有属主的文件
-nogroup          # 查找没有属组的文件

示例:

root@LeeMumu:~# find -user root
./sort.txt
./patch.txt
./5.txt
./1.txt
./.bash_history

2.1.3 根据文件的类型查找

-type TYPE:
	f   # 普通文件
	d   # 目录文件
	l   # 符号链接文件
	b   # 块设备 文件
	c   # 字符设备文件
	p   # 管道文件
	s   # 套接字文件

示例:

root@LeeMumu:~# find -user root -type f
./sort.txt
./patch.txt
./5.txt
./1.txt
./.bash_history

2.1.4 组合测试

与    # -a, 默认组合逻辑
或    # -o
非    # -not, !

!A -a !B = !(A -o B)
!A -o !B = !(A -a B)

2.1.5 根据文件的大小查找

-size [+|-]#UNIT
	常用单位:k, M, G
							
	#UNIT(#-1, #]
	-#UNIT[0,#-1]
	+#UNIT(#, oo)

2.1.6 根据时间戳查找

1、以“天”为单位:
	-atime  [+|-]#
		#:[#, #-1)
		-#(#, 0]
		+#(oo, #-1]
	-mtime
	-ctime
							
2、以“分钟”为单位:
	-amin
	-mmin
	-cmin

2.1.7 根据权限查找:

-perm  [/|-]mode
	mode:精确权限匹配
	/mode:任何一类用户(u,g,o)的权限中的任何一位(r,w,x)符合条件即满足
		9位权限之间存在“或”关系
	-mode:每一类用户(u,g,o)的权限中的每一位(r,w,x)同时符合条件即满足
		9位权限之间存在“与”关系

2.2 处理动作

-print:输出至标准输出;默认的动作
-ls:类似于对查找到的文件执行“ls -l”命令,输出文件的详细信息
-delete:删除查找到的文件
-fls /PATH/TO/SOMEFILE:把查找到的所有文件的长格式信息保存至指定文件中
-ok COMMAND {} \;  :对查找到的每个文件执行由COMMAND表示的命令;每次操作都由用户进行确认
-exec COMMAND {} \; :对查找到的每个文件执行由COMMAND表示的命令		

注意:

1、find传递查找到的文件路径至后面的命令时,是先查找出所有符合条件的文件路径,
   并一次性传递给后面的命令。
2、但是有些命令不能接受过长的参数,此时命令执行会失败;另一种方式可规避此问题:
	#find | xargs COMMAND

示例:

1、查找/var目录下属主为root,且属组为mail的所有文件或目录
	~]# find /var -user root -a -group mail -ls

2、查找/usr目录下不属于root, bin或hadoop的所有文件或目录;用两种方法
	~]# find /usr -not -user root -a -not -user bin -a -not -user hadoop
	~]# find /usr -not \( -user root -o -user bin -o -user hadoop \) -ls
					
3、查找/etc目录下最近一周内其内容修改过,且属主不是root用户也不是hadoop用户的文件或目录
	~]# find /etc -mtime -7 -a -not \( -user root -o -user hadoop \) -ls
	~]# find /etc -mtime -7 -a -not -user root -a -not -user hadoop -ls
					
4、查找当前系统上没有属或属组,且最近一周内曾被访问过的文件或目录
	~]# find  /  \( -nouser -o -nogroup \)  -atime  -7  -ls
					
5、查找/etc目录下大于1M且类型为普通文件的所有文件
	~]# find /etc -size +1M -type f -exec ls -lh {} \;
					
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 -perm -113 -type f -ls

你可能感兴趣的:(Linux学习笔记,Linux,命令查找)