find總結及練習

文件查找:

find文件查找.png

在文件系統上查找符合條件的文件;
文件查找:locate, find非實時查找(數據庫查找):locate
實時查找:find

locate:

依賴于事先構建的索引;索引的構建是在系統較為空閑時自動進行(周期性任務);手動更新數據庫(updatedb);
索引構建過程需要遍歷整個根文件系統,極消耗資源;

工作特點: 查找速度快; 模糊查找; 非實時查找;

locate KEYWORD

find:

實時查找工具,通過遍歷指定路徑下的文件系統完成文件查找;

工作特點: 查找速度略慢; 精確查找; 實時查找;

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

查找條件: 根據文件名查找:

-name "文件名稱":支持使用glob
*, ?, [], [^]
find /etc -name "passwd*"  :以什么開頭的文件
find /etc -name "*passwd":以什么結尾的文件
find /etc -name"*passwd*":中間出現passwd的文件

查找/etc下的passwd的文件

find /etc/ -name "*passwd"

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

查找/root下的abc文件,不區分大小寫

find /root/ -iname "abc"

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

根據屬主、屬組查找:

-user USERNAME:查找屬主為指定用戶的文件;-group GRPNAME: 查找屬組為指定組的文件;-uid UserID:查找屬主為指定的UID號的文件;-gid GroupID:查找屬組為指定的GID號的文件;		-nouser:查找沒有屬主的文件;					-nogroup:查找沒有屬組的文件;

根據文件類型查找:

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

組合條件:

與:-a或:-o
非:-not, !
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)                         如果整個條件取反本來是-a變-o

找出/tmp目錄下,屬主不是root,且文件名不是fstab的文件;

find /tmp \( -not -user root -a -not -name 'fstab' \) -ls
find /tmp -not \( -user root -o -name 'fstab' \) -ls

根據文件大小來查找:

-size [+|-]#UNIT常用單位:k, M, G#UNIT: (#-1, #]-3 小于等于3,大于3-1-#UNIT:[0,#-1]  3,從0開始,小于3-1				+#UNIT:(#,oo)>3到所有

根據時間戳:

以“天”為單位;
-atime [+|-]#,  #: [#,#+1):大于等于這個數字,小于這個數字加1
+#: [#+1,oo]:這個數字+1,到無窮-#: [0,#)0,到這個數字-mtime-ctime以“分鐘”為單位:
-amin-mmin-cmin

根據權限查找: -perm [/|-]MODE

MODE: 精確權限匹配
/MODE:任何一類(u,g,o)對象的權限中只要能一位匹配即可;							-MODE:每一類對象都必須同時擁有為其指定的權限標準;

處理動作:

-print:默認的處理動作,顯示至屏幕;			-ls:類似于對查找到的文件執行“ls -l”命令;	-delete:刪除查找到的文件;-fls /path/to/somefile:查找到的所有文件的長格式信息保存至指定文件中;-ok COMMAND {} \; 對查找到的每個文件執行由COMMAND指定的命令;	對于每個文件執行命令之前,都會交互式要求用戶確認;-exec COMMAND {} \; 對查找到的每個文件執行由COMMAND指定的命令; 
{}: 用于引用查找到的文件名稱自身;
find /tmp  -cmin 5 -exec mv {} {}.new \;		注意:find傳遞查找到的文件至后面指定的命令時,查找到所有符合條件的文件一次性傳遞給后面的命令;					有些命令不能接受過多參數,此時命令執行可能會失敗;另一種方式可規避此問題:
find | xargs COMMAND

練習:

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

find /var -user root -group mail

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

find /usr -not -user root -a -not -user bin -a -not -user hadoopfind /usr -not \( -user root -o -user bin -o -user hadoop \)

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

find /etc -mtime -7 -a -not -user root -a -not -user hadoopfind /etc/ -mtime -7 -a -not \( -user root -o -user hadoop \)

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

find / -nouser -a -nogroup -a -atime -7

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

find /etc -size +1M -type f

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

find /etc -not -perm /222

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

find /etc -not -perm -111

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

find /etc/init.d -perm -113

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

find /var/ -user root -a -group mail -ls

10、查找當前系統上沒有屬主或屬組的文件;

find /home  -nouser -a -nogroup

進一步:查找當前系統上沒有屬主或屬組,且最近3天內曾被訪問過的文件或目錄;

find /home -nouser -a -nogroup -atime -3

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

find /var -perm -222 -ls

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

find /etc -size +1M -type f

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

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

14、查找/usr目錄下不屬于root、bin或hadoop的文件;

find /usr -not -user root -a -not -user bin -a -not -user hadoopfind /usr -not \( -user root -o -user bin -o -user hadoop \)

15、查找/etc/目錄下至少有一類用戶沒有寫權限的文件;

find /etc -not -perm /222

16、查找/etc目錄下最近一周內其內容被修改過,且不屬于root或hadoop的文件;

find / -nouser -a -nogroup -a -atime -7

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

(0)
N21_ DominicN21_ Dominic
上一篇 2016-07-22
下一篇 2016-07-22

相關推薦

  • OpenSSL 的使用詳解

    OpenSSL 是一個開源項目,其組成主要包括一下三個組件:     openssl:多用途的命令行工具     libcrypto:加密算法庫     libssl:加密模塊應用庫,實現了ssl及tls openssl可以實現:秘鑰證書管…

    Linux干貨 2016-09-23
  • 權限管理

    linux文件權限:     在linux系統中,每個文件或目錄都包含有相應的權限,這些權限決定了哪些用戶或組能夠對此文件做哪些操作,如讀取、刪除、寫入等操作 文件權限分為三類:r,w,x     應用于文件:      &nbs…

    Linux干貨 2016-08-07
  • vim編輯器

    vim編輯器: 文本編輯器:文本,純文本,ASCII text;Unicode; 文本編輯種類:                 行編輯器:sed                全屏編輯器:…

    2017-04-17
  • 馬哥linux0803作業內容

    1. 創建sysadmins組 將用戶user1,user2,user3加入sysadmins組中 將user3設置為sysadmins的管理員 用user3登錄,將user2從組中移除 設置sysadmins的密碼centos 設置user1 在創建新文件時,文件的所屬組為sysadmins 刪除user1…3 刪除sysadmins 2、三種權限rwx對…

    Linux干貨 2016-08-04
  • 推薦-tree命令的安裝和使用

    一、前言     tree命令是可以把指定文件夾的所以文件用樹狀羅列出來,呈現目錄形式的一個命令。在Centos 6.5中默認不能直接使用: 輸入type tree命令(type COMMAND:區別是內建命令還是外部命令)提示不存在: 二、安裝       …

    系統運維 2016-03-27
  • Linux用戶和組管理

    進程以其發起者的身份運行; 進程對文件的訪問權限,取決于發起此進程的用戶的權限;   系統用戶:為了能夠讓那后臺進程或服務類進程以非管理員的身份運行,通常需要為此創建多個普通用戶;這類用戶從不用登錄系統;     groupadd命令:添加組   groupadd [選項] group_name   -g G…

    Linux干貨 2016-11-21

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-07-22 10:17

    寫的很好,排版也很棒,加油

欧美性久久久久