Unix find 命令詳解

jopen 12年前發布 | 1K 次閱讀

     由于find具有強大的功能,所以它的選項也很多,其中大部分選項都值得我們花時間來了解一下。即使系統中含有網絡文件系統( N F S ),find命令在該文件系統中同樣有效,只你具有相應的權限。
    在運行一個非常消耗資源的find命令時,很多人都傾向于把它放在后臺執行,因為遍歷一個大的文件系統可能會花費很長的時間(這里是指3 0 G字節以上的文件系統)。

Find命令的一般形式為:
find pathname -options [-print -exec -ok]
先了解一下find所帶的參數,能實現哪些功能
find命令選項
-name:按照文件名查找文件。
-perm:按照文件權限來查找文件。
-prune:使用這一選項可以使find命令不在當前指定的目錄中查找,如果同時使用-depth選項,那么-prune將被find命令忽略。
-user: 按照文件屬主來查找文件。
-group:按照文件所屬的組來查找文件。
-mtime -n +n:按照文件的更改時間來查找文件, - n表示文件更改時間距現在n天以內,+ n表示文件更改時間距現在n天以前。find命令還有- a t i m e和- c t i m e選項,但它們都和- mtime選項。
-nogroup:查找無有效所屬組的文件,即該文件所屬的組在/etc/g r o u p s中不存在。
-nouser:查找無有效屬主的文件,即該文件的屬主在/etc/passwd中不存在。
-newer file1 ! file2:查找更改時間比文件f i l e 1新但比文件f i l e 2舊的文件。
-type 查找某一類型的文件,諸如:
       b - 塊設備文件。d - 目錄。c - 字符設備文件。p - 管道文件。l - 符號鏈接文件。f - 普通文件。
-size n:[c] 查找文件長度為n塊的文件,帶有c時表示文件長度以字節計。
-depth:在查找文件時,首先查找當前目錄中的文件,然后再在其子目錄中查找。
-fstype:查找位于某一類型文件系統中的文件,這些文件系統類型通常可以在配置文件/etc/fstab中找到,該配置文件中包含了本系統中有關文件系統的信息。
-mount:在查找文件時不跨越文件系統m o u n t點。
-follow:如果find命令遇到符號鏈接文件,就跟蹤至鏈接所指向的文件。
-cpio:對匹配的文件使用c p i o命令,將這些文件備份到磁帶設備中。

 

下面這個選項我覺得這個很好用,說明下:
使用exec或ok來執行shell命令

使用find時,只要把想要的操作寫在一個文件里,就可以用exec來配合find查找,很方便的(在有些操作系統中只允許- e x e c選項執行諸如l s或ls -l這樣的命令)。大多數用戶使用這一選項是為了查找舊文件并刪除它們。建議在真正執行r m命令刪除文件之前,最好先用l s命令看一下,確認它們是所要刪除的文件。

exec選項后面跟隨著所要執行的命令或腳本,然后是一對兒{ },一個空格和一個\,最后是一個分號。為了使用exec選項,必須要同時使用print選項。如果驗證一下find命令,會發現該命令只輸出從當前路徑起的相對路徑及文件名。

例如:為了用ls -l命令列出所匹配到的文件,可以把ls -l命令放在find命令的- e x e c選項中
# find . -type f -exec ls -l {} \;
-rw-r--r--      1 root        root              34928 2003-02-25  ./conf/httpd.conf
-rw-r--r--      1 root        root              12959 2003-02-25  ./conf/magic
-rw-r--r--      1 root        root                  180 2003-02-25  ./conf.d/README
上面的例子中,find命令匹配到了當前目錄下的所有普通文件,并在-exec選項中使用ls -l命令將它們列出。
在/ l o g s目錄中查找更改時間在5日以前的文件并刪除它們:
    $ find logs -type f -mtime +5 -exec rm {} \;
    記住,在s h e l l中用任何方式刪除文件之前,應當先查看相應的文件,一定要小心!當使用諸如m v或r m命令時,可以使用- e x e c選項的安全模式。它將在對每個匹配到的文件進行操作之前提示你。

在下面的例子中, find命令在當前目錄中查找所有文件名以. LOG結尾、更改時間在5日以上的文件,并刪除它們,只不過在刪除之前先給出提示。

$ find . -name "*.conf"  -mtime +5 -ok rm {} \;

< rm ... ./conf/httpd.conf > ? n

按y鍵刪除文件,按n鍵不刪除。

 

任何形式的命令都可以在- exec選項中使用。

在下面的例子中我們使用grep命令。find命令首先匹配所有文件名為“ passwd*”的文件,例如passwd、passwd.old、passwd.bak,然后執行grep命令看看在這些文件中是否存在一個sam用戶。
# find /etc -name "passwd*" -exec grep "sam" {} \;
sam:x:501:501::/usr/sam:/bin/bash

 

find命令的例子
1.查找當前用戶主目錄下的所有文件,下面兩種方法都可以使用:
  $ find $HOME -print
  $ find ~ -print
2.為了在當前目錄中文件屬主具有讀、寫權限,并且文件所屬組的用戶和其他用戶具有讀權限的文件,可以用:
  $ find . -type f -perm 644 -exec ls -l {} \;
3.為了查找系統中所有文件長度為0的普通文件,并列出它們的完整路徑,可以用:
  $ find / -type f -size 0 -exec ls -l {} \;
4.查找/var/logs目錄中更改時間在7日以前的普通文件,并在刪除之前詢問它們:
  $ find /var/logs -type f -mtime +7 -ok rm {} \;
5.為了查找系統中所有屬于root組的文件,可以用:
    $find . -group root -exec ls -l {} \;
      -rw-r--r--      1 root        root                  595 10月 31 01:09 ./fie1
6.下面的find命令將刪除當目錄中訪問時間在7日以來、含有數字后綴的admin.log文件。該命令只檢查三位數字,所以相應文件的后綴不要超過999。
先建幾個admin.log*的文件 ,才能使用下面這個命令
    $ find . -name "admin.log[0-9][0-9][0-9]" -atime -7  -ok rm {} \;
      < rm ... ./admin.log001 > ? n
      < rm ... ./admin.log002 > ? n
      < rm ... ./admin.log042 > ? n
      < rm ... ./admin.log942 > ? n
7.為了查找當前文件系統中的所有目錄并排序,可以用:
      $ find . -type d  |sort
8.為了查找系統中所有的r m t磁帶設備,可以用:
      $ find /dev/rmt -print
9.為了查找當前文件系統中的所有目錄并排序,可以用:
      $ find . -type d |sort

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!