Linux locate命令的使用方法

01. 命令概述

locate命令其实是find -name的另一种写法,但是要比后者快得多,原因在于它不搜索具体目录,而是搜索一个数据库/var/lib/locatedb,这个数据库中含有本地所有文件信息。Linux系统自动创建这个数据库,并且每天自动更新一次,所以使用locate命令查不到最新变动过的文件。为了避免这种情况,可以在使用locate之前,先使用updatedb命令,手动更新数据库。

02. 命令格式

  locate [OPTION]… [PATTERN]…

03. 常用选项

  用法: locate [OPTION]... [PATTERN]...  在mlocate数据库中搜索条目.   -A, --all   只显示匹配所有模式的条目   -b, --basename     匹配唯一的路径名称的基本文件名   -c, --count      只显示找到条目的号码   -d, --database DBPATH 用 DBPATH 替代默认的数据库(/var/lib/mlocate/mlocate.db)   -e, --existing     只显示当前存在的文件条目   -L, --follow      当文件存在时跟随蔓延的符号链接 (默认)   -h, --help       显示本帮助   -i, --ignore-case   匹配模式时忽略大小写区别   -l, --limit, -n LIMIT 限制为 LIMIT项目的输出 (或 计数)    -m, --mmap       忽略向后兼容性   -P, --nofollow, -H   当检查文件时不跟随蔓延的符号链接   -0, --null       输出时以 NUL 分隔项目   -S, --statistics    不搜索项目,显示有关每个已用数据库的统计信息   -q, --quiet      不报告关于读取数据库的错误消息   -r, --regexp REGEXP  搜索基本正则表达式 REGEXP 来代替模式     --regex      模式是扩展正则表达式   -s, --stdio      忽略向后兼容性   -V, --version     显示版本信息   -w, --wholename    匹配完整路径名 (默认)

04. 参考示例

4.1 查找包含某个字符串的相关文件

  [root@localhost ~]# locate ifconfig   /home/oracle/app/oracle/product/11.2.0/dbhome_1/sysman/admin/scripts/ifconfig.sh  /usr/libexec/hypervkvpd/hv_set_ifconfig  /usr/sbin/ifconfig  /usr/sbin/pifconfig  /usr/share/man/de/man8/ifconfig.8.gz  /usr/share/man/fr/man8/ifconfig.8.gz  /usr/share/man/man8/ifconfig.8.gz  /usr/share/man/man8/pifconfig.8.gz  /usr/share/man/pt/man8/ifconfig.8.gz  /usr/share/man/zh_CN/man8/ifconfig.8.gz  [root@localhost ~]#     

4.2 搜索目录下所有以 sh开头的文件

  [root@localhost ~]# locate /bin/sh  /home/oracle/app/oracle/product/11.2.0/dbhome_1/perl/bin/shasum  /usr/bin/sh  /usr/bin/sha1sum  /usr/bin/sha224sum  /usr/bin/sha256sum  /usr/bin/sha384sum    

4.3 指定显示数量

如果显示的内容过多,可以使用 -n 选项来限定显示数量。

  [root@localhost ~]# locate -n 3 passwd  /etc/passwd  /etc/passwd-  /etc/pam.d/passwd  [root@localhost ~]#     

4.4 匹配模式时忽略大小写区别

当查找不需要区分大小写时,使用 -i 选项。

  [root@localhost ~]# locate -i -n 5 passwd  /etc/passwd  /etc/passwd-  /etc/pam.d/passwd  /etc/security/opasswd  /home/oracle/app/oracle/product/11.2.0/dbhome_1/apex/images/htmldb/icons/32x32/item_passwd.gif  [root@localhost ~]# 

4.5 搜索基本正则表达式 REGEXP 来代替模式

当需要查找符合特定规则的信息时,可以使用 -r 选项匹配相应的正则表达式。

  //查找以/var/lib/rpm开头的文件  [root@localhost ~]# locate -r ^/var/lib/rpm  /var/lib/rpm  /var/lib/rpm-state  /var/lib/rpm/.dbenv.lock  /var/lib/rpm/.rpm.lock  /var/lib/rpm/Basenames  /var/lib/rpm/Conflictname  /var/lib/rpm/Dirnames  /var/lib/rpm/Group  /var/lib/rpm/Installtid

  //查找etc.conf结尾的文件  [root@localhost ~]# locate -r etc.conf$  /usr/lib/tmpfiles.d/etc.conf  [root@localhost ~]# 

4.6 查找最近变动的文件

  # 新建文件  [root@localhost ~]# touch new_file  [root@localhost ~]# locate ~/new_file  [root@localhost ~]# updatedb  [root@localhost ~]# locate ~/new_file  /root/new_file  [root@localhost ~]#   # 删除文件  [root@localhost ~]# rm -rf file.txt   [root@localhost ~]# locate ~/file.txt  /root/file.txt  [root@localhost ~]# updatedb  [root@localhost ~]# locate ~/file.txt  [root@localhost ~]# 

注意:使用 locate 命令查不到最近变动过的文件。为了避免这种情况,可以在使用 locate 之前,先使用 updatedb 命令,手动更新数据库。

4.7 查看统计信息

  [deng@localhost test]$ locate -S   数据库 /var/lib/mlocate/mlocate.db:      18,935 文件夹      231,751 文件      13,753,723 文件名中的字节数      5,707,750 字节用于存储数据库  [deng@localhost test]$ 

4.8 查看passwd统计数量

  [root@localhost /]# locate -c passwd  183  [root@localhost /]# 

4.9 update相关配置文件

  [root@localhost /]# vim /etc/updatedb.conf   [root@localhost /]# 

到此这篇关于Linux locate命令的使用方法的文章就介绍到这了,更多相关Linux locate命令内容请搜素脚本之家以前的文章或下面相关文章,希望大家以后多多支持脚本之家!

参与评论