find命令詳解

文件查找

  • 在文件系統(tǒng)上查找符合條件的文件;
  • 實(shí)現(xiàn)工具: find,locate

1.find:

  • 實(shí)時(shí)查找工具:通過遍歷指定起始路徑下文件系統(tǒng)層級(jí)結(jié)構(gòu)完成文件查找;

工作特性:

  • 查找速度略慢;
  • 精確查找;
  • 實(shí)時(shí)查找;

用法:

 find [OPTION] [查找起始路徑] [查找條件] [處理動(dòng)作]
  • 查找起始路徑:指定具體搜索目標(biāo)起始路徑;默認(rèn)為當(dāng)前目錄;
  • 查找條件:指定的查找標(biāo)準(zhǔn),可以根據(jù)文件名、大小、類型、從屬關(guān)系、權(quán)限等標(biāo)準(zhǔn)進(jìn)行;默認(rèn)為找出指定路徑下的所有文件;
  • 處理動(dòng)作:對(duì)符合查找條件的文件做出的操作,例如刪除等操作;默認(rèn)為輸出至標(biāo)準(zhǔn)輸出;

查找條件

(1)根據(jù)文件名查找:

-name pattern
-iname pattern

  • 支持glob風(fēng)格的通配符;
*,?,[],[^]

-regex pattern:基于正則表達(dá)式模式查找文件,匹配范圍是整個(gè)路徑,而非基名;

(2)根據(jù)文件從屬關(guān)系查找:
-user USERNAME:查找屬主指定用戶的所有文件;
-group GRPNAME:查找屬組指定組的所有文件;
-uid UID:查找屬主指定的UID的所有文件;
-gid GID:查找屬組指定的GID的所有文件;
-nouser:查找沒有屬主的文件;
-nogroup:查找沒有屬組的文件;

練習(xí):

1.查找/home下面屬于distro的文件
[root@localhost ~]# find /home -user distro
/home/abc2
/home/abc2/.bash_profile
/home/abc2/.bash_logout
/home/abc2/.gnome2
/home/abc2/.bashrc
/home/distro
......
2.查找系統(tǒng)中不屬于任何人的文件
[root@localhost ~]# find / -nouser
/home/dlut2
/home/dlut2/.bash_profile
/home/dlut2/.bash_logout
/home/dlut2/.gnome2
/home/dlut2/.bashrc
/home/user21
......
//如果將系統(tǒng)里面某個(gè)賬號(hào)刪除了,但是該賬號(hào)已經(jīng)在系統(tǒng)內(nèi)穿件很多文件時(shí),會(huì)出現(xiàn)沒有屬主的文件,需要用-nouser將該類文件找出!
(3)根據(jù)文件的類型查找:
  • -type TYPE:
f:普通文件
d:目錄文件
l:符號(hào)鏈接文件
b:塊設(shè)備文件
c:字符設(shè)備文件
p:管道文件
s:套接字文件
(4)組合測(cè)試:
與:-a,默認(rèn)組合邏輯;
或:-o
非:-not,!
(5)根據(jù)文件大小查找:

-size[+|-]#UNIT
常用單位:K,M,G

 #UNIT:(#-1,#]
-#UNIT:[0,#-1]
+#UNIT:(#,oo)
(6)根據(jù)時(shí)間戳查找:

以“天”為單位:

-atime [+|-]#
   #:[#,#-1)
  -#:(#,0]
  +#:(oo,#-1]
-mtime
-ctime
(7)以“分鐘”為單位
-amin
-mmin
-cmin
(8)根據(jù)權(quán)限來(lái)查找:
  • -perm[/|-]mode
 mode:精確權(quán)限匹配;
/mode:任何一類用戶(u,g,o)的權(quán)限中的任何一位(r,w,x)符合條件即滿足;
-mode:每一類用戶(u,g,o)的權(quán)限中的每一位(r,w,x)同時(shí)符合條件即滿足;
9位權(quán)限之間存在“或”關(guān)系;

處理動(dòng)作:

  • find | xargs COMMAND
-print:輸出至標(biāo)準(zhǔn)輸出;默認(rèn)動(dòng)作;
-ls:類似對(duì)于查找到的文件執(zhí)行“l(fā)s -l”命令,輸出文件的詳細(xì)信息;
-delete:刪除查找到的文件;
-fls /PATH/TO/SOMEFILE:把查找到的所有文件的長(zhǎng)格式信息保存至指定文件中; 
-ok COMMAND{}\; :對(duì)查找到的每個(gè)文件執(zhí)行由COMMAND表示的命令;
            find ./ -nouser -a -nogroup -ok chown root:root {} \
-exec COMMAND {} \:對(duì)查找的每個(gè)文件執(zhí)行由COMMAND表示的命令;
注意:find傳遞查找到的文件路徑至后面的命令時(shí),是先查找出所有符合條件的文件路徑,并一次性傳遞給后面的命令;
     但是有些命令不能接受過長(zhǎng)的參數(shù),此時(shí)命令執(zhí)行失?。涣硪环N方式可規(guī)避此問題;

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

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

2. 查找/usr目錄下不屬于root或bin的所有文件或目錄;

[root@localhost ~]# find /user -not -user root -o -not -user bin 
/user/www
/user/www/.bash_profile
/user/www/.gnome2
/user/www/.bash_logout
/user/www/.bashrc
  1. 查找/etc目錄下最近一周內(nèi)其內(nèi)容修改過,且屬主不是root用戶也不是Hadoop用戶的文件或目錄;
    ~]#find /etc -mtime -7 -a -not -user root -a -not -user hadoop

    ~]# find /etc -mtime -7 -a -not \( -user root -o -user hadoop \)
  1. 查找當(dāng)前系統(tǒng)上沒有屬主或?qū)俳M,且最近一周內(nèi)曾被訪問過的文件或目錄;
     ~]#find /etc \( -nouser -o -nogroup \) -atime -7
  1. 查找/etc目錄下大于1M且類型為普通文件的所有文件;
[root@localhost ~]# find /etc -size +1M -exec ls -lh {} \;
-rw-r--r--. 1 root root 6.3M 7月   2 2017 /etc/selinux/targeted/policy/policy.24
-rw-r--r--. 1 root root 6.3M 7月   2 2017 /etc/selinux/targeted/modules/active/policy.kern

6.查找/etc目錄下所有用戶都沒有寫權(quán)限的文件;

 [root@localhost~]# find /etc -perm /222 -ls
  1. 查找/etc目錄至少有一類用戶沒有執(zhí)行權(quán)限的文件;
[root@localhost ~]#find /etc -not -perm -111 -type f -ls

8.查找/etc/init.d目錄下,所有用戶都有執(zhí)行權(quán)限,且其它用戶有寫權(quán)限的所有文件;

[root@localhost~]#find /etc -perm -113 -type f -ls

2.locate命令

  • 依賴于事先構(gòu)建好的索引庫(kù);
  • 系統(tǒng)自動(dòng)實(shí)現(xiàn)(周期性任務(wù));
  • 手動(dòng)更新數(shù)據(jù)庫(kù)(updatedb);

工作特性:

  • 查找速度快;
  • 模糊查找;
  • 非實(shí)時(shí)查找;

命令格式

locate [OPTION]... PATTERN...

常用選項(xiàng)

-b:只匹配路徑中的基名;
-c:統(tǒng)計(jì)出共有多少個(gè)符合條件的文件;
-r:BRE
注意:索引構(gòu)建過程需要遍歷整個(gè)根文件系統(tǒng),極消耗資源;

3.whereis

命令格式

whereis  [-bmsu]  文件或目錄名

常用選項(xiàng)

-b:只找二進(jìn)制格式的文件;
-m:只找在說(shuō)明文件manual路徑下的文件;
-s:只找source源文件;
-u:查找不在上述三個(gè)選項(xiàng)當(dāng)中的其他特殊文件;

練習(xí)

[root@localhost ~]# whereis ifconfig
ifconfig: /sbin/ifconfig /usr/share/man/man8/ifconfig.8.gz
[root@localhost ~]# su - distro
[distro@localhost ~]$ whereis ifconfig
ifconfig: /sbin/ifconfig /usr/share/man/man8/ifconfig.8.gz
[distro@localhost ~]$ exit
logout
  • 參考書籍《鳥哥的Linux私房菜--基礎(chǔ)學(xué)習(xí)篇》
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Linux系統(tǒng)「文件查找」 Linux系統(tǒng)文件中常用屬性為以下內(nèi)容:名稱,大小,權(quán)限,屬主,屬組,修改時(shí)間,訪問時(shí)...
    魏鎮(zhèn)坪閱讀 8,033評(píng)論 0 3
  • 用法總結(jié)如下:find pathname -options [-print -exec -ok]pathname:...
    L_luky閱讀 616評(píng)論 0 1
  • Ubuntu的發(fā)音 Ubuntu,源于非洲祖魯人和科薩人的語(yǔ)言,發(fā)作 oo-boon-too 的音。了解發(fā)音是有意...
    螢火蟲de夢(mèng)閱讀 100,708評(píng)論 9 468
  • 從我記憶的起點(diǎn)就有她,一個(gè)不那么起眼,不動(dòng)聲色默默堅(jiān)持自己的女生。她是我的同桌,是我最好的朋友,我認(rèn)為她是這個(gè)世...
    我在看著你呢閱讀 161評(píng)論 0 0
  • 父母是最愛你們的 你們就是他的心肝寶貝 所以相信父母
    道德講座閱讀 212評(píng)論 0 1

友情鏈接更多精彩內(nèi)容