文件的查找命令 find 和 locate

文件的查找命令 find 和 locate

find

功能:實時查找工具,通過遍歷指定路徑完成文件查找

工作特點:

?  查找速度略慢
?  精確查找
?  實時查找
?  可能只搜索用戶具備讀取和執行權限的目錄

語法:

  find [OPTION]… [查找路徑] [查找條件] [處理動作]

查找路徑:指定具體目標路徑;默認為當前目錄
查找條件:指定的查找標準,可以文件名、大小、類型、權限等標準進行;默認為找出指定路徑下的所有文件
處理動作:對符合條件的文件做操作,默認輸出至屏幕

find 查找條件

根據文件名和inode查找:

  • -name "文件名稱":支持使用glob

  • *, ?, [], [^]

  • -iname "文件名稱":不區分字母大小寫

  • -inum n  按inode號查找

  • -samefile name  相同inode號的文件

  • -links n  鏈接數為n的文件

  • -regex "PATTERN":以PATTERN匹配整個文件路徑字符串,而不僅僅是文件名稱

        find -name snow.png
      ? 搜索名為snow.png的文件
        find -iname snow.png
      ? 不分大小寫地搜索名為snow.png、Snow.png、SNOW.PNG等等的文件
       find / -name “*.txt”  搜索后綴為.txt的文件
       find /var –name “*log*”

根據屬主、屬組查找:

  • -user USERNAME:查找屬主為指定用戶(UID)的文件

  • -group GRPNAME: 查找屬組為指定組(GID)的文件

  • -uid UserID:查找屬主為指定的UID號的文件

  • -gid GroupID:查找屬組為指定的GID號的文件

  • -nouser:查找沒有屬主的文件

  • -nogroup:查找沒有屬組的文件

       find -user joe  -group joe
       搜索被用戶joe 以及組群joe所擁有的文件

根據文件類型查找:

-type TYPE:

?  f: 普通文件
?  d: 目錄文件
?  l: 符號鏈接文件
?  s:套接字文件
?  b: 塊設備文件
?  c: 字符設備文件
?  p: 管道文件

組合條件:

與:-a
或:-o
非:-not, !

德· 摩根定律:
(非 P) 或 (非 Q) = 非(P 且 Q)
(非 P) 且 (非 Q) = 非(P 或 Q)

 示例:
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)
找出/tmp目錄下,屬主不是root,且文件名不以f開頭的文件
    find /tmp \( -not -user root -a -not -name 'f*' \) -ls
    find /tmp -not \( -user root -o -name 'f*' \)  –ls

根據文件大小來查找:

-size [+|-] #計算單位    

常用單位:b,c,w,k, M, G

  • 10k 表示(9k,10k]

  • -6k 表示[0,5k]

  • +8k 表示(8k,+∞)

根據時間戳:

以“天”為單位;

  • -atime [+|-]#,

    • #: [#,#+1)

    • +#: [#+1,∞]

    • -#: [0,#)

  • -mtime

  • -ctime

以“分鐘”為單位:

  • -amin

  • -mmin

  • -cmin

      訪問時間(-atime/天,-amin/分鐘):用戶最近一次訪問時間。 
      修改時間(-mtime/天,-mmin/分鐘):文件最后一次修改時間。 
      變化時間(-ctime/天,-cmin/分鐘):文件數據元(例如權限等)最后一次修改時間。

根據權限查找:

-perm [/|-]MODE
MODE: 精確權限匹配

  • /MODE:任何一類(u,g,o)對象的權限中只要能一位匹配即可,或關系,+ 從centos7開始淘汰

  • -MODE:每一類對象都必須同時擁有指定權限,與關系

    ?0 表示不關注

? find -perm 755 會匹配權限模式恰好是755的文件

? 只要當任意人有寫權限時,find -perm +222就會匹配

? 只有當每個人都有寫權限時,find -perm -222才會匹配

? 只有當其它人(other)有寫權限時,find -perm -002才
會匹配

find 處理動作

  • -print:默認的處理動作,表示顯示至屏幕;

  • -ls:類似于對查找到的文件執行“ls -l”命令

  • -delete:刪除查找到的文件;

  • -fls file:查找到的所有文件的長格式信息保存至指定文件中

  • -ok COMMAND {} \; 對查找到的每個文件執行由COMMAND指定的命令;對于每個文件執行命令之前,都會交互式要求用戶確認()

  • -exec COMMAND {} \;

    • 對查找到的每個文件執行由COMMAND指定的命令

注意:

{} \;    : 用于引用查找到的文件名稱自身
find傳遞查找到的文件至后面指定的命令時,查找到所有符合條件的文件一次性傳遞給后面的命令
有些命令不能接受過多參數,此時命令執行可能會失敗,下面方式可規避此問題
find | xargs COMMAND

示例
 find  -name “*.conf”  -exec cp {} {}.org  \;
? 備份配置文件,添加.orig這個擴展名

 find /tmp -ctime +3 -user joe -ok rm {} \;
? 提示刪除存在時間超過3天以上的joe的臨時文件

 find ~ -perm -002  -exec chmod o-w {} \;
? 在你的主目錄中尋找可被其它用戶寫入的文件,并去掉寫權限

 find /data –type f -perm 644  -name “*.sh” –exec chmod 755 {} \;
 找出/date 權限為644的普通文件,并把他們改成755

 find /home –type d -ls
 找出/home 下的目錄文件,并列出

關于 -exec和 xargs
該命令的主要功能是從輸入中構建和執行shell命令。

 在使用find命令的-exec選項處理匹配到的文件時,   find命令將所有匹配到的文件一起傳遞給exec執行。但有些系統對能夠傳遞給exec的命令長度有限制,這樣在find命令運行幾分鐘之后,就會出現 溢出錯誤。錯誤信息通常是“參數列太長”或“參數列溢出”。這就是xargs命令的用處所在,特別是與find命令一起使用。  
find命令把匹配到的文件傳遞給xargs命令,而xargs命令每次只獲取一部分文件而不是全部,不像-exec選項那樣。這樣它可以先處理最先獲取的一部分文件,然后是下一批,并如此繼續下去。  
在有些系統中,使用-exec選項會為處理每一個匹配到的文件而發起一個相應的進程,并非將匹配到的文件全部作為參數一次執行;這樣在有些情況下就會出現進程過多,系統性能下降的問題,因而效率不高;  
而使用xargs命令則只有一個進程。另外,在使用xargs命令時,究竟是一次獲取所有的參數,還是分批取得參數,以及每一次獲取參數的數目都會根據該命令的選項及系統內核中相應的可調參數來確定。

find其他技巧

排除目錄

? 示例:查找/etc/下,除/etc/sane.d目錄的其它所有.conf后綴的文件
    find /etc -path ‘/etc/sane.d’ -a -prune -o -name “*.conf” -print

文件的查找命令 find 和 locate
注意:    -path  /root/bin -a  -prune  -o
      表示裁剪/root/bin 里面的內容  再搜索

要列出所有長度為零的文件

find . -type f -empty

[root@localhost ~]# find . -type f -empty -exec rm  {} \; 
[root@localhost ~]# find . -type f -empty

一點練習

1、查找/var目錄下屬主為root,且屬組為mail的所有文件

[root@localhost ~]# find /var -user root -group mail
/var/spool/mail
/var/spool/mail/root

2、查找/var目錄下不屬于root、lp、gdm的所有文件

 find /var \( -not -user root -a -not -user lp -a -not -user gdm \)  -ls

3、查找/var目錄下最近一周內其內容修改過,同時屬主不為root,也不是postfix的文件

# find /var \( -mtime -7 -a -not -user root -a -not -user postfix \) -ls

4、查找當前系統上沒有屬主或屬組,且最近一個周內曾被訪問過的文件

find / \( -nouser -nogroup -atime -7 \) -ls

5、查找/etc目錄下大于1M且類型為普通文件的所有文件

[root@localhost ~]# find /etc -size +1M -type f

6、查找/etc目錄下所有用戶都沒有寫權限的文件

# find /etc/ -not -perm /222 -ls

7、查找/etc目錄下至少有一類用戶沒有執行權限的文件

# find /etc/ -not -perm -111 -ls

8、查找/etc/init.d目錄下,所有用戶都有執行權限,且其它用戶有寫權限的文件

# find /etc/init.d -perm -113

locate

功能:查詢系統上預建的文件索引數據庫     /var/lib/mlocate/mlocate.db

  • 依賴于事先構建的索引

  • 索引的構建是在系統較為空閑時自動進行(周期性任務),管理員手動更新數據庫(updatedb)

  • 索引構建過程需要遍歷整個根文件系統,極消耗資源

工作特點:

? 查找速度快
? 模糊查找
? 非實時查找
? 搜索的是文件的全路徑,不僅僅是文件名
? 可能只搜索用戶具備讀取和執行權限的目錄

語法: locate [選項] KEYWORD

有用的選項

  • ? -i 執行區分大小寫的搜索

  • ? -n N 只列舉前N個匹配項目

    • locate foo

  • ? 搜索名稱或路徑中帶有“foo”的文件

    • locate  -r ‘.foo$’

  • ? 使用Regex來搜索以“.foo”結尾的文件

搜索etc目錄下所有以sh開頭的文件:

locate /etc/sh

搜索用戶主目錄下,所有以m開頭的文件:

locate ~/m

搜索用戶主目錄下,所有以m開頭的文件,并且忽略大小寫:

locate -i ~/m

原創文章,作者:qzx,如若轉載,請注明出處:http://www.www58058.com/36179

(0)
qzxqzx
上一篇 2016-08-16
下一篇 2016-08-16

相關推薦

  • Linux基礎知識及常用命令

    pwd:printing working directory -顯示當前工作目錄            [root@edu tmp]# pwd          &nbs…

    Linux干貨 2016-09-15
  • redis主從復制(4)— client buffer

    1、 client buffer的設計 redis server以單進程的方式處理接收到的請求,而redis完成請求有些工作比較慢,比如網絡IO和磁盤IO等比較慢的操作。redis為了提高處理客戶端請求的響應時間,做了很多優化。比如網絡io和磁盤io是異步完成、使用后臺進程完成bgsave和bgrewriteaof工作,在server端為客戶提供讀buffe…

    Linux干貨 2016-03-28
  • linux中的磁盤陣列(RAID)

    RAID: Redundant Arrays of Inexpensive Disks  Independent 提高IO能力: 通過磁盤并行讀寫實現 提高耐用性能: 磁盤冗余來實現 級別: 多塊磁盤組織在一起的工作方式有所不同: RAID是的方式: 外接式磁盤陣列: 通過擴展卡提供適配能力 內接式RAID: 主板集成RAID控制器 Softwar…

    Linux干貨 2016-08-29
  • yum –rpm前端工具詳解

     1、yum 介紹        YUM: Yellowdog Update Modifier, rpm的前端程序,用來解決軟件包相關依賴性,可以在多個庫之間定位軟件包,up2date的替代工具        &nbsp…

    Linux干貨 2016-08-24
  • 進程查看管理工具htop/dstat/top/ps

    ps:顯示系統當前進程的運行情況         選項與參數(一):            a:所有與終端相關的進程;    x:所有與終端無關的進程;    u:以用戶為中心組織進程狀態信息顯示;   &nb…

    2016-12-04

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-08-18 15:31

    總結的很好,很詳細,排版精美,再接再厲。

欧美性久久久久