前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux locate命令的使用方法

Linux locate命令的使用方法

作者头像
砸漏
发布2020-10-21 22:36:55
2.2K0
发布2020-10-21 22:36:55
举报
文章被收录于专栏:恩蓝脚本

01. 命令概述

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

02. 命令格式

代码语言:javascript
复制
locate [OPTION]… [PATTERN]…

03. 常用选项

代码语言:javascript
复制
用法: 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 查找包含某个字符串的相关文件

代码语言:javascript
复制
[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开头的文件

代码语言:javascript
复制
[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 选项来限定显示数量。

代码语言:javascript
复制
[root@localhost ~]# locate -n 3 passwd
/etc/passwd
/etc/passwd-
/etc/pam.d/passwd
[root@localhost ~]# 

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

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

代码语言:javascript
复制
[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 选项匹配相应的正则表达式。

代码语言:javascript
复制
//查找以/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
代码语言:javascript
复制
//查找etc.conf结尾的文件
[root@localhost ~]# locate -r etc.conf$
/usr/lib/tmpfiles.d/etc.conf
[root@localhost ~]# 

4.6 查找最近变动的文件

代码语言:javascript
复制
# 新建文件
[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 查看统计信息

代码语言:javascript
复制
[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统计数量

代码语言:javascript
复制
[root@localhost /]# locate -c passwd
183
[root@localhost /]# 

4.9 update相关配置文件

代码语言:javascript
复制
[root@localhost /]# vim /etc/updatedb.conf 
[root@localhost /]# 

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 01. 命令概述
  • 02. 命令格式
  • 03. 常用选项
  • 04. 参考示例
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档