find
find 命令用于在一个或多个目录树中查找文件,搜索条件包括名称、时间戳或大小等。
find 命令使用所有或部分名称,或者使用其他搜索条件(比如大小、类型、文件所有者、创建日期或最后访问日期)来搜索文件或目录。最基本的 find 格式是按名称或名称的一部分来搜索。
ian@Z61t-u14:~/lpi103-2$ find . -name "*[1k]*"
./text10
./f1a
./backup
./backup/text1.bkp.2
./backup/text1.bkp.1
./f1
./text1
按类型查找文件
ian@Z61t-u14:~/lpi103-2$ find . -type d
../backup
ian@Z61t-u14:~/lpi103-2$ find . -type d -name "*"
../backup
安装文件大小搜索
您还可以按文件大小进行搜索,搜索特定大小的文件 (n) 或大于 (+n) 或小于给定值 (-n) 的文件。通过使用大小上限和下限,可以找到大小在给定范围内的文件。默认情况下,find 的 -size 选项会假设单位 “b” 表示 512 字节的数据块。在其他选择中,指定 “c” 表示字节,或者指定 “k” 表示 kb。
ian@Z61t-u14:~/lpi103-2$ find . -size 0
./f1a./f2
ian@Z61t-u14:~/lpi103-2$ find . -size -26c -size +23c -print
./text2
./text5
./backup/text1.bkp.2
./backup/text1.bkp.1
./text1
which、type 和 whereis 命令
which 命令
可以使用 which 命令搜索您的路径,找到在您键入一个命令时将执行哪个命令(如果有)。
[ian@atticf22 ~]$ echo $PATH
/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:/home/ian/.local/bin:/home/ian/bin
[ian@atticf22 ~]$ which hello
/usr/bin/which: no hello in (/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:
/home/ian/.local/bin:/home/ian/bin)
[ian@atticf22 ~]$ export PATH=~/test-hello:$PATH
[ian@atticf22 ~]$ echo $PATH
/home/ian/test-hello:/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin:
/home/ian/.local/bin:/home/ian/bin
[ian@atticf22 ~]$ which hello
~/test-hello/hello
which 命令显示了一个命令在您的路径中第一次出现的位置。如果您想知道该命令是否出现了多次,可以添加 -a 选项,例如:
[ian@atticf22 ~]$ which awk
/usr/bin/awk
[ian@atticf22 ~]$ which -a awk
/usr/bin/awk
/bin/awk
[ian@atticf22 ~]$ ls -l $(which -a awk)
lrwxrwxrwx. 1 root root 4 Jan 2 2015 /bin/awk -> gawk
lrwxrwxrwx. 1 root root 4 Jan 2 2015 /usr/bin/awk -> gawk
[ian@atticf22 ~]$ ls -ld /bin /usr/bin
lrwxrwxrwx. 1 root root 7 Aug 16 2014 /bin -> usr/bin
dr-xr-xr-x. 2 root root 69632 Aug 10 10:40 /usr/bin
find 命令
find 命令就像是 Linux 系统上的文件搜索工具的瑞士军刀。您可能发现有用的另外两个功能是:它可以基于用户或组名称来查找文件,或者基于权限来查找文件。
[root@atticf22 ~]# find /tmp -user ian
/tmp/jna-104022
...
/tmp/hsperfdata_ian
/tmp/hsperfdata_ian/2390
/tmp/tracker-extract-files.1000
/tmp/.esd-1000
/tmp/.esd-1000/socket
/tmp/.X11-unix/X0
/tmp/.ICE-unix/1668
您还可以使用 -group 测试来按组查找文件。您可以使用 -nouser 和 -nogroup 选项找到不属于系统上的任何用户或组的文件。与其他测试一样,您可以使用 ! 对该测试求反。
[ian@atticf22 ~]$ find -L research -maxdepth 2 -type d ! -group ian
research/rh62/involution
research/rh62/programs
research/lost+found
find: ‘ research/lost+found ’ : Permission denied
[ian@atticf22 ~]$ ls -ld research/rh62/involution
drwxr-xr-x. 2 500 adm 4096 Nov 10 1999 research/rh62/involution
按照权限查找文件
要按权限查找文件,可以使用 -perm 测试和类似 chmod 或 umask 命令所使用的符号表达式。您可以搜索准确的权限,但更有用的做法通常是在权限表达式前添加一个连字符作为前缀,以表明您想要设置了这些权限的文件,但并不关心其他权限。下面演示了如何查找用户、组和每个人可执行的文件,以及查找其他用户无法读取的文件的两种不同方式。
[ian@atticf22 ~]$ find . -maxdepth 1 -type f -perm -uga=x
./hello
[ian@atticf22 ~]$ find . -maxdepth 1 ! -perm -o=r
.
./.ssh
./.ICEauthority
./.bash_history
./.config
...
./.kde
./.cache
[ian@atticf22 ~]$ find . -maxdepth 1 ! -perm -0004
.
./.ssh
./.ICEauthority
./.bash_history
./.config
...
./.kde
./.cache
find 使用正则表达式
[ian@atticf22 ~]$ cd /usr/include
[ian@atticf22 include]$ find . -iregex ".*packet.*"
./net/if_packet.h
./linux/packet_diag.h
./linux/if_packet.h
./netpacket
./netpacket/packet.h
[ian@atticf22 include]$ find . -iregex ".*packet.*" ! -type d -size +1500c
./linux/packet_diag.h
./linux/if_packet.h
./netpacket/packet.h
locate 和 updatedb 命令
在每次运行 find 命令时,该命令都会搜索您指定的所有目录。要加快运行速度,可以使用另一个命令 locate,它使用已存储路径信息的数据库,而不是每次都搜索文件系统。
locate 命令
locate 命令搜索通常由一个计划作业每天更新的数据库中的匹配文件。
locate 命令与路径名的任何部分匹配,而不只是与文件名匹配。将文件名放在单引号中,并包含至少一个通配符来更准确地匹配。下例展示了如何查找包含字符串 bin/ls 的路径,还展示了两个使用通配符来限制输出的示例。
[ian@attic4-cent ~]$ locate /bin/ls
/bin/ls
/bin/lsblk
/bin/lscgroup
/bin/lssubsys
/usr/bin/lsattr
/usr/bin/lsb_release
/usr/bin/lscpu
/usr/bin/lsdiff
/usr/bin/lshal
/usr/bin/lslogins
/usr/bin/lsusb
/usr/bin/lsusb.py
[ian@attic4-cent ~]$ locate '\/bin/ls'
/bin/ls
[ian@attic4-cent ~]$ locate '/bin/ls*'
/bin/ls
/bin/lsblk
/bin/lscgroup
/bin/lssubsys
updatedb 命令
locate 使用的默认数据库存储在 /var 文件系统中的一个位置中,比如 /var/lib/locatedb。这个位置在使用 slocate 或 mlocate 包来提供额外的安全性或更高速度的系统上可能不同。您可以使用 locate -S 查找您的 locate 数据库上的统计数据。
[ian@attic4-cent ~]$ locate -S
Database /var/lib/mlocate/mlocate.db:
77,143 directories
776,460 files
56,872,710 bytes in file names
21,074,461 bytes used to store datab
使用 updatedb 命令创建或更新该数据库。该命令通常作为计划作业每天运行。文件 /etc/updatedb.conf(或者有时候是/etc/sysconfig/locate)是 updatedb 的配置文件。要启用每日更新,root 用户需要编辑 /etc/updatedb.conf 并设置 DAILY_UPDATE=yes。要立即创建该数据库,可以 root 身份运行 updatedb 命令。