Linux下which、whereis、locate命令的区别

  我们经常在linux要查找某个文件,但不知道放在哪里了,可以使用下面的一些命令来搜索。 

  • which       查看可执行文件的位置 
  • whereis    查看文件的位置 
  • locate       配合数据库查看文件位置 

 一  which

which是通过 PATH环境变量 到该路径内查找可执行文件,所以基本的功能是寻找可执行文件

[root@VM_0_15_centos ~]# which   passwd 
/usr/bin/passwd

 二 whereis

参数说明:  
-b : 只找二进制文件  
-m: 只找在说明文件manual路径下的文件  
-s : 只找source源文件  
-u : 没有说明文档的文件  

将和passwd相关的文件全部查找出来

[root@VM_0_15_centos ~]# whereis   passwd
passwd: /usr/bin/passwd /etc/passwd /usr/share/man/man1/passwd.1.gz

只将二进制文件查找出来

[root@VM_0_15_centos ~]# whereis  -b  passwd
passwd: /usr/bin/passwd /etc/passwd

和find相比,whereis查找的速度非常快,这是因为linux系统会将 系统内的所有文件都记录在一个数据库文件中,当使用whereis和下面即将介绍的locate时,会从数据库中查找数据,而不是像find命令那样,通 过遍历硬盘来查找,效率自然会很高。 
但是该数据库文件并不是实时更新,默认情况下时一星期更新一次,因此,我们在用whereis和locate 查找文件时,有时会找到已经被删除的数据,或者刚刚建立文件,却无法查找到,原因就是因为数据库文件没有被更新

 三  locate

语法:locate 文件或者目录名称  

[root@VM_0_15_centos ~]# locate  passwd
/etc/passwd
/etc/passwd-
/etc/pam.d/passwd
/etc/security/opasswd
/home/test/passwd
/usr/bin/gpasswd
/usr/bin/grub2-mkpasswd-pbkdf2
/usr/bin/passwd
/usr/include/rpcsvc/yppasswd.h
/usr/include/rpcsvc/yppasswd.x
/usr/lib/firewalld/services/kpasswd.xml
/usr/lib/x86_64-redhat-linux6E/include/rpcsvc/yppasswd.h
/usr/lib/x86_64-redhat-linux6E/include/rpcsvc/yppasswd.x
/usr/lib64/security/pam_unix_passwd.so
/usr/sbin/chpasswd
/usr/sbin/lpasswd

 

原文地址:https://www.cnblogs.com/wzy23/p/11377821.html