<dfn id="w48us"></dfn><ul id="w48us"></ul>
  • <ul id="w48us"></ul>
  • <del id="w48us"></del>
    <ul id="w48us"></ul>
  • Linux文件查找命令find和xargs詳解

    時間:2024-09-29 01:49:53 計算機應(yīng)用 我要投稿
    • 相關(guān)推薦

    Linux文件查找命令find和xargs詳解

      下面是YJBYS小編為大家?guī)淼奈募檎颐頵ind,Linux,xargs的區(qū)別詳解,希望對你有所幫助!

      前言:關(guān)于find命令

      由于find具有強大的功能,所以它的選項也很多,其中大部分選項都值得我們花時間來了解一下。即使系統(tǒng)中含有網(wǎng)絡(luò)文件系統(tǒng)( NFS),find命令在該文件系統(tǒng)中同樣有效,只你具有相應(yīng)的權(quán)限。

      在運行一個非常消耗資源的find命令時,很多人都傾向于把它放在后臺執(zhí)行,因為遍歷一個大的文件系統(tǒng)可能會花費很長的時間(這里是指30G字節(jié)以上的文件系統(tǒng))。

      一、find 命令格式

      1、find命令的一般形式為;

      find pathname -options [-print -exec -ok ...]

      2、find命令的參數(shù);

      pathname: find命令所查找的目錄路徑。例如用.來表示當前目錄,用/來表示系統(tǒng)根目錄。

      -print: find命令將匹配的文件輸出到標準輸出。

      -exec: find命令對匹配的文件執(zhí)行該參數(shù)所給出的shell命令。相應(yīng)命令的形式為’command’ {} \;,注意{}和\;之間的空格。

      -ok: 和-exec的作用相同,只不過以一種更為安全的模式來執(zhí)行該參數(shù)所給出的shell命令,在執(zhí)行每一個命令之前,都會給出提示,讓用戶來確定是否執(zhí)行。

      3、find命令選項

      -name

      按照文件名查找文件。

      -perm

      按照文件權(quán)限來查找文件。

      -prune

      使用這一選項可以使find命令不在當前指定的目錄中查找,如果同時使用-depth選項,那么-prune將被find命令忽略。

      -user

      按照文件屬主來查找文件。

      -group

      按照文件所屬的組來查找文件。

      -mtime -n +n

      按照文件的更改時間來查找文件, – n表示文件更改時間距現(xiàn)在n天以內(nèi),+ n表示文件更改時間距現(xiàn)在n天以前。find命令還有-atime和-ctime 選項,但它們都和-m time選項。

      -nogroup

      查找無有效所屬組的文件,即該文件所屬的組在/etc/groups中不存在。

      -nouser

      查找無有效屬主的文件,即該文件的屬主在/etc/passwd中不存在。

      -newer file1 ! file2

      查找更改時間比文件file1新但比文件file2舊的文件。

      -type

      查找某一類型的文件,諸如:

      b – 塊設(shè)備文件。

      d – 目錄。

      c – 字符設(shè)備文件。

      p – 管道文件。

      l – 符號鏈接文件。

      f – 普通文件。

      -size n:[c] 查找文件長度為n塊的文件,帶有c時表示文件長度以字節(jié)計。

      -depth:在查找文件時,首先查找當前目錄中的文件,然后再在其子目錄中查找。

      -fstype:查找位于某一類型文件系統(tǒng)中的文件,這些文件系統(tǒng)類型通常可以在配置文件/etc/fstab中找到,該配置文件中包含了本系統(tǒng)中有關(guān)文件系統(tǒng)的信息。

      -mount:在查找文件時不跨越文件系統(tǒng)mount點。

      -follow:如果find命令遇到符號鏈接文件,就跟蹤至鏈接所指向的文件。

      -cpio:對匹配的文件使用cpio命令,將這些文件備份到磁帶設(shè)備中。

      另外,下面三個的區(qū)別:

      -amin n

      查找系統(tǒng)中最后N分鐘訪問的文件

      -atime n

      查找系統(tǒng)中最后n*24小時訪問的文件

      -cmin n

      查找系統(tǒng)中最后N分鐘被改變文件狀態(tài)的文件

      -ctime n

      查找系統(tǒng)中最后n*24小時被改變文件狀態(tài)的文件

      -mmin n

      查找系統(tǒng)中最后N分鐘被改變文件數(shù)據(jù)的文件

      -mtime n

      查找系統(tǒng)中最后n*24小時被改變文件數(shù)據(jù)的文件

      4、使用exec或ok來執(zhí)行shell命令

      使用find時,只要把想要的操作寫在一個文件里,就可以用exec來配合find查找,很方便的

      在有些操作系統(tǒng)中只允許-exec選項執(zhí)行諸如l s或ls -l這樣的命令。大多數(shù)用戶使用這一選項是為了查找舊文件并刪除它們。建議在真正執(zhí)行rm命令刪除文件之前,最好先用ls命令看一下,確認它們是所要刪除的文件。

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

      例如:為了用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中用任何方式刪除文件之前,應(yīng)當先查看相應(yīng)的文件,一定要小心!當使用諸如mv或rm命令時,可以使用-exec選項的安全模式。它將在對每個匹配到的文件進行操作之前提示你。

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

      $ find . -name “*.log” -mtime +5 -ok rm {} \;

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

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

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

      在下面的例子中我們使用grep命令。find命令首先匹配所有文件名為“ passwd*”的文件,例如passwd、passwd.old、passwd.bak,然后執(zhí)行g(shù)rep命令看看在這些文件中是否存在一個sam用戶。

      # find /etc -name “passwd*” -exec grep “sam” {} \;

      sam:x:501:501::/usr/sam:/bin/bash

      二、find命令的例子;

      1、查找當前用戶主目錄下的所有文件:

      下面兩種方法都可以使用

      $ find $HOME -print

      $ find ~ -print

      2、讓當前目錄中文件屬主具有讀、寫權(quán)限,并且文件所屬組的用戶和其他用戶具有讀權(quán)限的文件;

      $ find . -type f -perm 644 -exec ls -l {} \;

      3、為了查找系統(tǒng)中所有文件長度為0的普通文件,并列出它們的完整路徑;

      $ find / -type f -size 0 -exec ls -l {} \;

      4、查找/var/logs目錄中更改時間在7日以前的普通文件,并在刪除之前詢問它們;

      $ find /var/logs -type f -mtime +7 -ok rm {} \;

      5、為了查找系統(tǒng)中所有屬于root組的文件;

      $find . -group root -exec ls -l {} \;

      -rw-r–r– 1 root root 595 10月 31 01:09 ./fie1

      6、find命令將刪除當目錄中訪問時間在7日以來、含有數(shù)字后綴的admin.log文件。

      該命令只檢查三位數(shù)字,所以相應(yīng)文件的后綴不要超過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、為了查找當前文件系統(tǒng)中的所有目錄并排序;

      $ find . -type d | sort

      8、為了查找系統(tǒng)中所有的rmt磁帶設(shè)備;

      $ find /dev/rmt -print

      三、xargs

      xargs – build and execute command lines from standard input

      在 使用find命令的-exec選項處理匹配到的文件時, find命令將所有匹配到的文件一起傳遞給exec執(zhí)行。但有些系統(tǒng)對能夠傳遞給exec的命令長度有限制,這樣在find命令運行幾分鐘之后,就會出現(xiàn) 溢出錯誤。錯誤信息通常是“參數(shù)列太長”或“參數(shù)列溢出”。這就是xargs命令的用處所在,特別是與find命令一起使用。

      find命令把匹配到的文件傳遞給xargs命令,而xargs命令每次只獲取一部分文件而不是全部,不像-exec選項那樣。這樣它可以先處理最先獲取的一部分文件,然后是下一批,并如此繼續(xù)下去。

      在有些系統(tǒng)中,使用-exec選項會為處理每一個匹配到的文件而發(fā)起一個相應(yīng)的進程,并非將匹配到的文件全部作為參數(shù)一次執(zhí)行;這樣在有些情況下就會出現(xiàn)進程過多,系統(tǒng)性能下降的問題,因而效率不高;

      而使用xargs命令則只有一個進程。另外,在使用xargs命令時,究竟是一次獲取所有的參數(shù),還是分批取得參數(shù),以及每一次獲取參數(shù)的數(shù)目都會根據(jù)該命令的選項及系統(tǒng)內(nèi)核中相應(yīng)的可調(diào)參數(shù)來確定。

      來看看xargs命令是如何同find命令一起使用的,并給出一些例子。

      下面的例子查找系統(tǒng)中的每一個普通文件,然后使用xargs命令來測試它們分別屬于哪類文件

      #find . -type f -print | xargs file

      ./.kde/Autostart/Autorun.desktop: UTF-8 Unicode English text

      ./.kde/Autostart/.directory: ISO-8859 text\

      ……

      在整個系統(tǒng)中查找內(nèi)存信息轉(zhuǎn)儲文件(core dump) ,然后把結(jié)果保存到/tmp/core.log 文件中:

      $ find / -name “core” -print | xargs echo “” >/tmp/core.log

      上面這個執(zhí)行太慢,我改成在當前目錄下查找

      #find . -name “file*” -print | xargs echo “” > /temp/core.log

      # cat /temp/core.log

      ./file6

      在當前目錄下查找所有用戶具有讀、寫和執(zhí)行權(quán)限的文件,并收回相應(yīng)的寫權(quán)限:

      # ls -l

      drwxrwxrwx 2 sam adm 4096 10月 30 20:14 file6

      -rwxrwxrwx 2 sam adm 0 10月 31 01:01 http3.conf

      -rwxrwxrwx 2 sam adm 0 10月 31 01:01 httpd.conf

      # find . -perm -7 -print | xargs chmod o-w

      # ls -l

      drwxrwxr-x 2 sam adm 4096 10月 30 20:14 file6

      -rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf

      -rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf

      用grep命令在所有的普通文件中搜索hostname這個詞:

      # find . -type f -print | xargs grep “hostname”

      ./httpd1.conf:# different IP addresses or hostnames and have them handled by the

      ./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames

      on your

      用grep命令在當前目錄下的所有普通文件中搜索hostnames這個詞:

      # find . -name \* -type f -print | xargs grep “hostnames”

      ./httpd1.conf:# different IP addresses or hostnames and have them handled by the

      ./httpd1.conf:# VirtualHost: If you want to maintain multiple domains/hostnames

      on your

      注意,在上面的例子中, \用來取消find命令中的*在shell中的特殊含義。

      find命令配合使用exec和xargs可以使用戶對所匹配到的文件執(zhí)行幾乎所有的命令。

      四、find 命令的參數(shù)

      下面是find一些常用參數(shù)的例子,有用到的時候查查就行了,像上面前幾個貼子,都用到了其中的的一些參數(shù),也可以用man或查看論壇里其它貼子有find的命令手冊

      1、使用name選項

      文件名選項是find命令最常用的選項,要么單獨使用該選項,要么和其他選項一起使用。

      可以使用某種文件名模式來匹配文件,記住要用引號將文件名模式引起來。

      不管當前路徑是什么,如果想要在自己的根目錄$HOME中查找文件名符合*.txt的文件,使用~作為 ‘pathname’參數(shù),波浪號~代表了你的$HOME目錄。

      $ find ~ -name “*.txt” -print

      想要在當前目錄及子目錄中查找所有的‘ *.txt’文件,可以用:

      $ find . -name “*.txt” -print

      想要的當前目錄及子目錄中查找文件名以一個大寫字母開頭的文件,可以用:

      $ find . -name “[A-Z]*” -print

      想要在/etc目錄中查找文件名以host開頭的文件,可以用:

      $ find /etc -name “host*” -print

      想要查找$HOME目錄中的文件,可以用:

      $ find ~ -name “*” -print 或find . -print

      要想讓系統(tǒng)高負荷運行,就從根目錄開始查找所有的文件。

      $ find / -name “*” -print

      如果想在當前目錄查找文件名以兩個小寫字母開頭,跟著是兩個數(shù)字,最后是.txt的文件,下面的命令就能夠返回名為ax37.txt的文件:

      $find . -name “[a-z][a-z][0--9][0--9].txt” -print

      2、用perm選項

      按照文件權(quán)限模式用-perm選項,按文件權(quán)限模式來查找文件的話。最好使用八進制的權(quán)限表示法。

      如在當前目錄下查找文件權(quán)限位為755的文件,即文件屬主可以讀、寫、執(zhí)行,其他用戶可以讀、執(zhí)行的文件,可以用:

      $ find . -perm 755 -print

      還有一種表達方法:在八進制數(shù)字前面要加一個橫杠-,表示都匹配,如-007就相當于777,-006相當于666

      # ls -l

      -rwxrwxr-x 2 sam adm 0 10月 31 01:01 http3.conf

      -rw-rw-rw- 1 sam adm 34890 10月 31 00:57 httpd1.conf

      -rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf

      drw-rw-rw- 2 gem group 4096 10月 26 19:48 sam

      -rw-rw-rw- 1 root root 2792 10月 31 20:19 temp

      # find . -perm 006

      # find . -perm -006

      ./sam

      ./httpd1.conf

      ./temp

      -perm mode:文件許可正好符合mode

      -perm +mode:文件許可部分符合mode

      -perm -mode: 文件許可完全符合mode

      3、忽略某個目錄

      如果在查找文件時希望忽略某個目錄,因為你知道那個目錄中沒有你所要查找的文件,那么可以使用-prune選項來指出需要忽略的目錄。在使用-prune選項時要當心,因為如果你同時使用了-depth選項,那么-prune選項就會被find命令忽略。

      如果希望在/apps目錄下查找文件,但不希望在/apps/bin目錄下查找,可以用:

      $ find /apps -path “/apps/bin” -prune -o -print

      4、使用find查找文件的時候怎么避開某個文件目錄

      比如要在/usr/sam目錄下查找不在dir1子目錄之內(nèi)的所有文件

      find /usr/sam -path “/usr/sam/dir1″ -prune -o -print

      find [-path ..] [expression] 在路徑列表的后面的是表達式

      -path “/usr/sam” -prune -o -print 是 -path “/usr/sam” -a -prune -o

      -print 的簡寫表達式按順序求值, -a 和 -o 都是短路求值,與 shell 的 && 和 || 類似如果 -path “/usr/sam” 為真,則求值 -prune , -prune 返回真,與邏輯表達式為真;否則不求值 -prune,與邏輯表達式為假。如果 -path “/usr/sam” -a -prune 為假,則求值 -print ,-print返回真,或邏輯表達式為真;否則不求值 -print,或邏輯表達式為真。

      這個表達式組合特例可以用偽碼寫為

      if -path “/usr/sam” then

      -prune

      else

      -print

      避開多個文件夾

      find /usr/sam \( -path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -print

      圓括號表示表達式的結(jié)合。

      \ 表示引用,即指示 shell 不對后面的字符作特殊解釋,而留給 find 命令去解釋其意義。

      查找某一確定文件,-name等選項加在-o 之后

      #find /usr/sam \(-path /usr/sam/dir1 -o -path /usr/sam/file1 \) -prune -o -name “temp” -print

      5、使用user和nouser選項

      按文件屬主查找文件,如在$HOME目錄中查找文件屬主為sam的文件,可以用:

      $ find ~ -user sam -print

      在/etc目錄下查找文件屬主為uucp的文件:

      $ find /etc -user uucp -print

      為了查找屬主帳戶已經(jīng)被刪除的文件,可以使用-nouser選項。這樣就能夠找到那些屬主在/etc/passwd文件中沒有有效帳戶的文件。在使用-nouser選項時,不必給出用戶名; find命令能夠為你完成相應(yīng)的工作。

      例如,希望在/home目錄下查找所有的這類文件,可以用:

      $ find /home -nouser -print

      6、使用group和nogroup選項

      就像user和nouser選項一樣,針對文件所屬于的用戶組, find命令也具有同樣的選項,為了在/apps目錄下查找屬于gem用戶組的文件,可以用:

      $ find /apps -group gem -print

      要查找沒有有效所屬用戶組的所有文件,可以使用nogroup選項。下面的find命令從文件系統(tǒng)的根目錄處查找這樣的文件

      $ find / -nogroup-print

      7、按照更改時間或訪問時間等查找文件

      如果希望按照更改時間來查找文件,可以使用mtime,atime或ctime選項。如果系統(tǒng)突然沒有可用空間了,很有可能某一個文件的長度在此期間增長迅速,這時就可以用mtime選項來查找這樣的文件。

      用減號-來限定更改時間在距今n日以內(nèi)的文件,而用加號+來限定更改時間在距今n日以前的文件。

      希望在系統(tǒng)根目錄下查找更改時間在5日以內(nèi)的文件,可以用:

      $ find / -mtime -5 -print

      為了在/var/adm目錄下查找更改時間在3日以前的文件,可以用:

      $ find /var/adm -mtime +3 -print

      8、查找比某個文件新或舊的文件

      如果希望查找更改時間比某個文件新但比另一個文件舊的所有文件,可以使用-newer選項。它的一般形式為:

      newest_file_name ! oldest_file_name

      其中,!是邏輯非符號。

      查找更改時間比文件sam新但比文件temp舊的文件:

      例:有兩個文件

      -rw-r–r– 1 sam adm 0 10月 31 01:07 fiel

      -rw-rw-rw- 1 sam adm 34890 10月 31 00:57 httpd1.conf

      -rwxrwxr-x 2 sam adm 0 10月 31 01:01 httpd.conf

      drw-rw-rw- 2 gem group 4096 10月 26 19:48 sam

      -rw-rw-rw- 1 root root 2792 10月 31 20:19 temp

      # find -newer httpd1.conf ! -newer temp -ls

      1077669 0 -rwxrwxr-x 2 sam adm 0 10月 31 01:01 ./httpd.conf

      1077671 4 -rw-rw-rw- 1 root root 2792 10月 31 20:19 ./temp

      1077673 0 -rw-r–r– 1 sam adm 0 10月 31 01:07 ./fiel

      查找更改時間在比temp文件新的文件:

      $ find . -newer temp -print

      9、使用type選項

      在/etc目錄下查找所有的目錄,可以用:

      $ find /etc -type d -print

      在當前目錄下查找除目錄以外的所有類型的文件,可以用:

      $ find . ! -type d -print

      在/etc目錄下查找所有的符號鏈接文件,可以用

      $ find /etc -type l -print

      10、使用size選項

      可以按照文件長度來查找文件,這里所指的文件長度既可以用塊(block)來計量,也可以用字節(jié)來計量。以字節(jié)計量文件長度的表達形式為N c;以塊計量文件長度只用數(shù)字表示即可。

      在按照文件長度查找文件時,一般使用這種以字節(jié)表示的文件長度,在查看文件系統(tǒng)的大小,因為這時使用塊來計量更容易轉(zhuǎn)換。

      在當前目錄下查找文件長度大于1 M字節(jié)的文件:

      $ find . -size +1000000c -print

      查找當前目錄中大于10M的文件:

      find . -size +10000k -exec ls -ld {} ;

      將find出來的文件復制到另一個地方:

      find *.c -exec cp ‘{}’ /tmp ‘;’

      在/home/apache目錄下查找文件長度恰好為100字節(jié)的文件:

      $ find /home/apache -size 100c -print

      在當前目錄下查找長度超過10塊的文件(一塊等于512字節(jié)):

      $ find . -size +10 -print

      11、使用depth選項

      在使用find命令時,可能希望先匹配所有的文件,再在子目錄中查找。使用depth選項就可以使find命令這樣做。這樣做的一個原因就是,當在使用find命令向磁帶上備份文件系統(tǒng)時,希望首先備份所有的文件,其次再備份子目錄中的文件。

      在下面的例子中, find命令從文件系統(tǒng)的根目錄開始,查找一個名為CON.FILE的文件。

      它將首先匹配所有的文件然后再進入子目錄中查找。

      $ find / -name “CON.FILE” -depth -print

      12、使用mount選項

      在當前的文件系統(tǒng)中查找文件(不進入其他文件系統(tǒng)),可以使用find命令的mount選項。

      從當前目錄開始查找位于本文件系統(tǒng)中文件名以XC結(jié)尾的文件:

      $ find . -name “*.XC” -mount -print

    【Linux文件查找命令find和xargs詳解】相關(guān)文章:

    linux常用基本命令(文件處理命令)11-29

    Linux文件系統(tǒng)操作命令大全03-09

    linux命令中su和sudo區(qū)別03-24

    Linux認證基礎(chǔ)知識:RedHat之vi命令詳解03-08

    Linux用戶/文件系統(tǒng)管理詳解02-27

    dos命令之REN命令-文件改名命令03-20

    dos命令之FC命令:文件比較命令08-07

    java開發(fā)必會的Linux命令03-24

    Linux中常用操作命令03-06

    主站蜘蛛池模板: 国产精品美女久久久久| 国产91大片精品一区在线观看 | 亚洲午夜精品一级在线播放放 | 免费人妻精品一区二区三区| 国产精品国产三级国产AV主播 | 国产精品福利在线观看免费不卡| 亚洲国产精品乱码一区二区| 精品人妻系列无码人妻免费视频| 久久精品国产免费| 激情亚洲一区国产精品| 亚洲精品成人片在线观看| 漂亮人妻被黑人久久精品| 国产偷亚洲偷欧美偷精品 | 欧美日韩精品一区二区| 久久国产精品成人影院| 人妻少妇精品久久| 国产精品毛片一区二区| 久久久久免费精品国产| 国产午夜无码精品免费看| 中文字幕久精品免费视频| 久久无码人妻精品一区二区三区 | 蜜桃麻豆www久久国产精品 | 日本伊人精品一区二区三区| 精品亚洲欧美无人区乱码| 自怕偷自怕亚洲精品| 国产原创精品视频| 99re这里只有精品国产精品| 精品亚洲成a人片在线观看| 午夜精品久久久久久99热| 亚洲国产成人精品女人久久久 | 55夜色66夜色国产精品视频| 特级精品毛片免费观看| 中文字幕精品亚洲无线码二区| 日本精品久久久久影院日本 | 国产精品对白交换视频| 欧美精品黑人粗大免费| 无码国产精品一区二区免费模式| 无码精品人妻一区二区三区漫画| 亚洲国产精品一区第二页| 日韩精品专区AV无码| 无码人妻精品一区二区三区66|