linux 下的find 命令 小總結..謝謝大家賞光!
通用格式:find pathname -options [-print -exec -ok]
例子:
find / -name filename 再根目錄裡面搜尋檔案名稱為filename的檔案
find /etc -name *s*在目錄裡面搜尋帶有s的檔案
find /etc -name *S 在目錄裡面搜尋以s結尾的檔案
find /etc -name s*在目錄裡面搜尋以s開頭的檔案
find / -amin -10在系統中搜尋最後10分鐘訪問的檔案
find / -atime -2尋找在系統中最後48小時訪問的檔案
find / -empty 尋找在系統中為空白的檔案或者是檔案夾
find / -group groupname 尋找在系統中屬於groupname的檔案
find / -mmin -5尋找在系統中最後5分鐘修改過的檔案
find / -mtime -1尋找在系統中最後24小時修改過的檔案
find /-nouser尋找在系統中屬於費使用者的檔案
find / -user username 尋找在系統中屬於username的檔案
find / -ctime -1尋找在系統中最後24小時被改變狀態的檔案
find / -fstype type尋找在系統中檔案類型為?的檔案
find / -user user1name -or -user user2name尋找在系統中屬於user1name或著屬於user2name的檔案
find / -user user1name -and -user2name在系統中尋找既屬於user1name又屬於user2name使用者的檔案.
一、find 命令格式
1、find命令的一般形式為;
find pathname -options [-print -exec -ok ...]
2、find命令的參數;
pathname: find命令所尋找的目錄路徑。例如用.來表示目前的目錄,用/來表示系統根目錄。
-print: find命令將匹配的檔案輸出到標準輸出。
-exec: find命令對匹配的檔案執行該參數所給出的shell命令。相應命令的形式為'command' { } /;,注意{ }和/;之間的空格。
-ok: 和-exec的作用相同,只不過以一種更為安全的模式來執行該參數所給出的shell命令,在執行每一個命令之前,都會給出提示,讓使用者來確定是否執行。
3、find命令選項
-name
按照檔案名稱尋找檔案。
-perm
按照檔案許可權來尋找檔案。
-prune
使用這一選項可以使find命令不在當前指定的目錄中尋找,如果同時使用-depth選項,那麼-prune將被find命令忽略。
-user
按照檔案屬主來尋找檔案。
-group
按照檔案所屬的組來尋找檔案。
-mtime -n +n
按照檔案的更改時間來尋找檔案, - n表示檔案更改時間距現在n天以內,+ n表示檔案更改時間距現在n天以前。find命令還有-atime和-ctime 選項,但它們都和-m time選項。
-nogroup
尋找無有效所屬組的檔案,即該檔案所屬的組在/etc/groups中不存在。
-nouser
尋找無有效屬主的檔案,即該檔案的屬主在/etc/passwd中不存在。
-newer file1 ! file2
尋找更改時間比檔案file1新但比檔案file2舊的檔案。
-type
尋找某一類型的檔案,諸如:
b - 塊裝置檔案。
d - 目錄。
c - 字元裝置檔案。
p - 管道檔案。
l - 符號連結檔案。
f - 普通檔案。
-size n:[c] 尋找檔案長度為n塊的檔案,帶有c時表示檔案長度以位元組計。
-depth:在尋找檔案時,首先尋找目前的目錄中的檔案,然後再在其子目錄中尋找。
-fstype:尋找位於某一類型檔案系統中的檔案,這些檔案系統類型通常可以在設定檔/etc/fstab中找到,該設定檔中包含了本系統中有關檔案系統的資訊。
-mount:在尋找檔案時不跨越檔案系統mount點。
-follow:如果find命令遇到符號連結檔案,就跟蹤至連結所指向的檔案。
-cpio:對匹配的檔案使用cpio命令,將這些檔案備份到磁帶裝置中。
另外,下面三個的區別:
-amin n
尋找系統中最後N分鐘訪問的檔案
-atime n
尋找系統中最後n*24小時訪問的檔案
-cmin n
尋找系統中最後N分鐘被改變檔案狀態的檔案
-ctime n
尋找系統中最後n*24小時被改變檔案狀態的檔案
-mmin n
尋找系統中最後N分鐘被改變檔案資料的檔案
-mtime n
尋找系統中最後n*24小時被改變檔案資料的檔案
4、使用exec或ok來執行shell命令
使用find時,只要把想要的操作寫在一個檔案裡,就可以用exec來配合find尋找,很方便的
在有些作業系統中只允許-exec選項執行諸如l s或ls -l這樣的命令。大多數使用者使用這一選項是為了尋找舊檔案並刪除它們。建議在真正執行rm命令刪除檔案之前,最好先用ls命令看一下,確認它們是所要刪除的檔案。
exec選項後面跟隨著所要執行的命令或指令碼,然後是一對兒{ },一個空格和一個/,最後是一個分號。為了使用exec選項,必須要同時使用print選項。如果驗證一下find命令,會發現該命令只輸出從當前路徑起的相對路徑及檔案名稱。
例如:為了用ls -l命令列出所匹配到的檔案,可以把ls -l命令放在find命令的-exec選項中
# 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命令將它們列出。
在/logs目錄中尋找更改時間在5日以前的檔案並刪除它們:
$ find logs -type f -mtime +5 -exec rm { } /;
記住:在shell中用任何方式刪除檔案之前,應當先查看相應的檔案,一定要小心!當使用諸如mv或rm命令時,可以使用-exec選項的安全模式。它將在對每個匹配到的檔案進行操作之前提示你。
在下面的例子中, 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