centos7上使用locate命令


小貼士:
在centOS7以上的系統中使用“locate”文件查找命令,發現該命令不可用。 檢查了下,原來是centos7默認沒有安裝該命令,在聯網狀態運行“yum install mlocate”命令即可安裝
"locate"命令。 安裝完之后運行“locate inittab”,發現結果如下:   locate: can not stat () `/var/lib/mlocate/mlocate.db': No such file or directory 並沒有查詢出相關文件,此時需要線運行下“updatedb”命令初始化一下文件庫,在運行“locate inittab”,發現結果如下:   /etc/inittab   /usr/share/vim/vim74/syntax/inittab.vim 這時“locate”命令就可以正確使用了。

 

1、命令簡介

 

locate(locate) 命令用來查找文件或目錄。 locate命令要比find -name快得多,原因在於它不搜索具體目錄,而是搜索一個數據庫/var/lib/mlocate/mlocate.db 。這個數據庫中含有本地所有文件信息。Linux系統自動創建這個數據庫,並且每天自動更新一次,因此,我們在用whereis和locate 查找文件時,有時會找到已經被刪除的數據,或者剛剛建立文件,卻無法查找到,原因就是因為數據庫文件沒有被更新。為了避免這種情況,可以在使用locate之前,先使用updatedb命令,手動更新數據庫。整個locate工作其實是由四部分組成的:

  1. /usr/bin/updatedb   主要用來更新數據庫,通過crontab自動完成的

  2. /usr/bin/locate         查詢文件位置

  3. /etc/updatedb.conf   updatedb的配置文件

  4. /var/lib/mlocate/mlocate.db  存放文件信息的文件

 

 

2、用法

 

locate [OPTION]... [PATTERN]...

 

 

3、選項

-b, --basename         match only the base name of path names
  -c, --count            只輸出找到的數量
  -d, --database DBPATH  使用DBPATH指定的數據庫,而不是默認數據庫 /var/lib/mlocate/mlocate.db
  -e, --existing         only print entries for currently existing files
  -L, --follow           follow trailing symbolic links when checking file existence (default)
  -h, --help             顯示幫助
  -i, --ignore-case      忽略大小寫
  -l, --limit, -n LIMIT  limit output (or counting) to LIMIT entries
  -m, --mmap             ignored, for backward compatibility
  -P, --nofollow, -H     don't follow trailing symbolic links when checking file existence
  -0, --null             separate entries with NUL on output
  -S, --statistics       don't search for entries, print statistics about eachused database
  -q, --quiet            安靜模式,不會顯示任何錯誤訊息
  -r, --regexp REGEXP    使用基本正則表達式
      --regex            使用擴展正則表達式
  -s, --stdio            ignored, for backward compatibility
  -V, --version          顯示版本信息
  -w, --wholename        match whole path name (default)

4、示例

示例1: 搜索etc目錄下所有以my開頭的文件
[root@py_unix ~]# locate /etc/my
/etc/my.cnf
/etc/my.cnf.d
/etc/my.cnf.d/mysql-clients.cnf
[root@py_unix ~]# 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM