locate
让使用者可以很快速的搜寻档案系统内是否有指定的档案。其方法是先建立一个包括系统内所有档案名称及路径的数据库,之后当寻找时就只需查询这个数据库,而不必实际深入档案系统之中了。在一般的 distribution 之中,数据库的建立都被放在 crontab 中自动执行。
Locate [选择参数] [样式]
locate
命令可以在搜寻数据库时快速找到档案,数据库由updatedb
程序来更新,updatedb是由cron daemon
周期性建立的,locate
命令在搜寻数据库时比由整个由硬盘资料来搜寻资料来得快,但较差劲的是locate
所找到的档案若是最近才建立或 刚更名的,可能会找不到,在内定值中,updatedb每天会跑一次,可以由修改crontab
来更新设定值。(etc/crontab
)
locate指定用在搜寻符合条件的档案,它会去储存档案与目录名称的数据库内,寻找合乎范本样式条件的档案或目录录,可以使用特殊字元(如”*
” 或”?
”等)来指定范本样式,如指定范本为kcpaner, locate
会找出所有起始字串为kcpa且结尾为ner的档案或目录,如名称为kcpartner若目录录名称为kcpa_ner*则会列出该目录下包括 子目录在内的所有档案。locate
指令和find找寻档案的功能类似,但locate
是透过update
程序将硬盘中的所有档案和目录资料先建立一个索引数据库,在 执行loacte
时直接找该索引,查询速度会较快,索引数据库一般是由操作系统管理,但也可以直接下达update
强迫系统立即修改索引数据库。
-e
- 将排除在寻找的范围之外。-1
- 如果是1
。则启动安全模式。在安全模式下,使用者不会看到权限无法看到的档案。这会始速度减慢,因为 locate
必须至实际的档案系统中取得档案的权限资料。-f
- 将特定的档案系统排除在外,例如没有到理要把 proc
档案系统中的档案放在资料库中。-q
安静模式,不会显示任何错误讯息。-n
至多显示 n
个输出。-r
使用正规运算式 做寻找的条件。-o
指定资料库存的名称。-d
指定资料库的路径-h
显示辅助讯息-V
显示程式的版本讯息注意:运行
locate
命令时,系统报错:locate: command not found。查了相关资料,发现原因是系统上没有该执行文件,就需要安装。解决方案如下:
执行命令:[root@localhost ~]#yum install locate
//看locate属于哪个软件包
查出来mlocate.x86_64 : An utility for finding files by name 执行:[root@localhost ~]#yum install mlocate
mlocate安装完成之后,再执行locate命令,就不会报错。实在不行,还可以使用命令:yum install *locate
来安装。执行 updatedb 手动构建库
[root@localhost ~]#updatedb
完成后就可以执行locate了
命令:
locate pwd
执行演示及输出:
[root@localhost zyiz]# locate pwd /etc/.pwd.lock /usr/bin/pwd /usr/bin/pwdx /usr/lib/modules/3.10.0-514.el7.x86_64/kernel/drivers/watchdog/hpwdt.ko /usr/lib64/cracklib_dict.pwd /usr/lib64/python2.7/lib-dynload/spwdmodule.so /usr/sbin/unix_chkpwd /usr/share/cracklib/cracklib-small.pwd /usr/share/cracklib/pw_dict.pwd /usr/share/man/man1/pwd.1.gz /usr/share/man/man1/pwdx.1.gz /usr/share/man/man8/unix_chkpwd.8.gz [root@localhost zyiz]#
命令:
locate /etc/sh
执行演示及输出:
[root@localhost zyiz]# locate /etc/sh /etc/shadow /etc/shadow- /etc/shells [root@localhost zyiz]#
命令:
locate /etc/i
执行演示及输出:
[root@localhost zyiz]# locate /etc/n /etc/networks /etc/nsswitch.conf /etc/nsswitch.conf.bak [root@localhost zyiz]# locate /etc/i /etc/init.d /etc/inittab /etc/inputrc /etc/iproute2 /etc/issue /etc/issue.net /etc/iproute2/ematch_map /etc/iproute2/group /etc/iproute2/nl_protos /etc/iproute2/rt_dsfield /etc/iproute2/rt_protos /etc/iproute2/rt_realms /etc/iproute2/rt_scopes /etc/iproute2/rt_tables [root@localhost zyiz]#