Linux下 which | whereis | locate | find的区别
which
查看可执行文件的位置whereis
查看文件的位置locate
配合数据库查看文件位置find
实际搜寻硬盘查询文件名称
1. find
find是最常用和最强大的查找命令。它能做到实时查找,精确查找,但速度慢。
find的使用格式如下:
find [指定目录] [指定条件] [指定动作]
- 指定目录:是指所要搜索的目录和其子目录。如果不指定,则默认为当前目录。
- 指定条件:是指所要搜索的文件的特点。
- 指定动作:是指对搜索的结果如何处理。
常见选项:
- -name 根据文件名称查找(严格区分大小写,如果文件名中间有空格,则必须把文件名用双引号引起来)
- -iname 根据文件名查找(不区分大小写)
- -regex “PATTERN” 正则表达式匹配
- -user 根据文件属主进行查找
- -group 根据文件属组进行查找
- -uid 根据文件的uid查找
- -gid 根据用户的gid查找
- -nouser 查看所有的没有属主的文件
- -nogroup 查看所有的没有属组的文件
举例
- 查看tmp目录下,文件属主为redhat的文件
#ls -l `find /tmp -user redhat`
- 查看根目录下文件或文件名为xxx的文件或文件夹
#find / -name xxx
2. whereis
whereis命令只能用于搜索程序名,而且只搜索二进制文件(参数-b)、man说明文件(参数-m)和源代码文件(参数-s)。如果省略参数,则返回所有信息。
语法:
whereis [-bmsu] 文件或者目录名称
参数说明:
-b
: 只找二进制文件-m
: 只找在说明文件manual路径下的文件-s
: 只找source源文件-u
: 没有说明文档的文件
例如:
[root@redhat ~]# whereis passwd
passwd: /usr/bin/passwd /etc/passwd /usr/bin/X11/passwd /usr/share/man/man5/passwd.5.gz /usr/share/man/man1/passwd.1.gz /usr/share/man/man1/passwd.1ssl.gz
将和passwd文件相关的文件都查找出来
[root@redhat ~]# whereis -b passwd
passwd: /usr/bin/passwd /etc/passwd /usr/bin/X11/passwd
只将二进制文件 查找出来
和find相比,whereis查找的速度非常快
这是因为linux系统会将系统内的所有文件都记录在一个数据库文件中,当使用whereis和下面即将介绍的locate时,会从数据库中查找数据,而不是像find命令那样,通过遍历硬盘来查找,效率自然会很高。
但是该数据库文件并不是实时更新,默认情况下时一星期更新一次,因此,我们在用whereis和locate 查找文件时,有时会找到已经被删除的数据,或者刚刚建立文件,却无法查找到,原因就是因为数据库文件没有被更新。
3. which
which命令是查找命令是否存在,以及命令的存放位置在哪儿。
语法:
which 可执行文件名称
例如:
[root@sys ~]# which passwd
/usr/bin/passwd
which是通过 PATH 环境变量到该路径内查找可执行文件,所以基本的功能是寻找可执行文件
4. locate
locate命令不是实时查找,所以查找的结果不精确,但查找速度很快。
因为它查找的不是目录,而是一个数据库(/var/lib /locatedb),这个数据库中含有本地所有文件信息。
Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最 新变动过的文件。
为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。
格式
locate 文件或者目录名称
例如:
查找所有包含passwd的文件
#locate passwd
查找所有包含passwd的文件,并且只显示前十个
#locate -n 10 passwd