洞悉find中的德摩根定律和條件權限perm

1.德摩根定律

(1)初悉德摩根定律兒

在命題邏輯和邏輯代數中,德·摩根定律(或稱德·摩根定理)是關于命題邏輯規律的一對法則。
奧古斯塔斯·德·摩根首先發現了在命題邏輯中存在著下面這些關系:
非(A 且 B) = (非 A) 或 (非 B)非(A 或 B) = (非 A) 且 (非 B)

(2)圖解德摩根定律

1>.非(A or B) = (非 A) and (非 B)

約定以下圖中矩形代表全部,圓A和圓B是矩形的一部分并有部分相交

imageAandB.PNG

1)A or B,如下圖中的黑色部分:
    屬于A或者是屬于B,即為圖中黑色部分

imageAandB1.PNG

2)非A and 非B    1.非A為B黃色部分加上矩形中黑色部分,非B為A橘色部分加矩形中黑色部分,而非A and 非B即是去除A也取出B,即僅剩下黑色部分;

image非Aand非B.PNG

3)由1)和2)中圖可以看出,1)中圖和2)中屬于非關系,即非1)為2),非2)為1);
所以 非(A or B)= (非 A) and (非 B)

2> 非(A and B) = (非 A) 或 (非 B)

1)非(A and B),A and B,即屬于A也屬于B的部分,二者的交集
對二者交集進行取反,則非(A and B)部分為下圖中黑色部分

image捕非(AandB)PNG.PNG

2)(非 A) 或 (非 B)
    非A即不屬于A的部分,下圖1
    非B即不屬于B的部分,下圖2
    兩者取或即為下圖3

圖1 image

非AandB.PNG 

圖2 

非BandA.PNGimage 

圖3 image

捕非(AandB)PNG.PNG

3)由1)和2)可以看出非(A and B) = (非 A) 或 (非 B)

(3)德摩根定律在find命令中的使用示例:

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

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

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

2.條件權限perm

(1)perm用處

可以根據文件不同用戶權限位,進行未見的查找動作,提高了文件查找的精確度。掌握該方式,可以使我們快捷有效的使用find從大量的系統文件中找到我們需要的文件。

(2)-perm的三種形式

find -perm modefind -perm -modefind -perm /mode1)mode:精確權限匹配,如:    find /root -perm 555 -ls
    查找/root下用戶組和其它用戶的權限均是讀和執行的文件,執行結果示例如下:
[root@CentOS6 Packages]# find /root -perm 555 -ls
    132235    4 -r-xr-xr-x   1 root     root         1343 Aug 13 18:31 /root/etc2016-08-13/rc.d/init.d/blk-availability    132261    4 -r-xr-xr-x   1 root     root         3045 Aug 13 18:31 /root/etc2016-08-13/rc.d/init.d/lvm2-monitor    132268    4 -r-xr-xr-x   1 root     root         2137 Aug 13 18:31 /root/etc2016-08-13/rc.d/init.d/lvm2-lvmetad
2)/MODE:任意一類(u,g,o)對象的權限中只要能一位匹配即可,或關系,(+從CentOS7開始淘汰)
查找/root/bin目錄下三類用戶至少有一類有寫權限的文件
find /root/bin -perm /222 -ls
[root@CentOS6 bin]# find /root/bin -perm /222 -ls131247    4 drwxr-xr-x   5 root     root         4096 Aug 14 21:05 /root/bin131246    4 drwxr-xr-x   3 root     root         4096 Aug 15 21:07 /root/bin/seatwork131242    4 -rwxr-xr--   1 root     root          100 Aug 11 17:14 /root/bin/seatwork/hostping.sh131241    4 -rwxr-xr--   1 root     root          149 Aug 11 14:54 /root/bin/seatwork/sumspace.sh
3)-MODE:每一類對象都必須同時擁有指定權限,與關系與關系0 表示此處的權限位不關心
查找三類用戶都必須有寫權限的文件
find /root/bin -perm -222 -ls
[root@CentOS6 bin]# find /root/bin -perm -222 -ls131246    4 drwx-wxrw-   3 root     root         4096 Aug 15 21:07 /root/bin/seatwork131242    4 -rwx-wxrw-   1 root     root          100 Aug 11 17:14 /root/bin/seatwork/hostping.sh131241    4 -rwx-wxrw-   1 root     root          149 Aug 11 14:54 /root/bin/seatwork/sumspace.sh131229    4 -rwx-wxrw-   1 root     root          142 Aug 11 14:51 /root/bin/seatwork/sumfile.sh131244    4 -rwx-wxrw-   1 root     root          142 Aug 11 17:47 /root/bin/seatwork/per.sh131248    4 -rwx-wxrw-   1 root     root           99 Aug 11 17:58 /root/bin/seatwork/login.sh137570    4 drwx-wxrw-   2 root     root         4096 Aug 15 16:26 /root/bin/seatwork/For137574    4 -rwx-wxrw-   1 root     root          797 Aug 15 13:11 /root/bin/seatwork/For/useradd.sh137573    4 -rwx-wxrw-   1 root     root          178 Aug 15 14:09 /root/bin/seatwork/For/multiplication.sh137571    4 -rwx-wxrw-   1 root     root          486 Aug 15 13:17 /root/bin/seatwork/For/rcfile.sh137572    4 -rwx-wxrw-   1 root     root          157 Aug 15 12:33 /root/bin/seatwork/For/varfile.sh131243    4 -rwx-wxrw-   1 root     root          111 Aug 11 17:56 /root/bin/seatwork/nologin.sh131233    4 -rwx-wxrw-   1 root     root          150 Aug 11 15:03 /root/bin/seatwork/sumid.sh131245    4 -rwx-wxrw-   1 root     root          138 Aug 11 17:20 /root/bin/seatwork/argsnum.sh131228    4 -rwx-wxrw-   1 root     root          158 Aug 11 16:36 /root/bin/seatwork/checkdisk.sh

總結: 對于德摩根定律和條件權限perm是find命令使用過程中的兩個難點,需要多對其進行練習和理解。以便在以后的文件查找中,提高工作工作效率。

3.find 練習題

1、查找/var目錄下屬主為root,且屬組為mail的所有文件
    find /var/ -user root -group mail -ls 
1+.查找/var目錄下屬主不為root,且屬組不為mail的所有文件
    find /var/ -not -user root -a -not -group mail
    find /var/ -not \( -user root -o -group mail \)2、查找/var目錄下不屬于root、lp、gdm的所有文件
    find /var/ -not -user root -a -not -user lp -a  -not -user gdm -ls
    find /var/ -not \( -user root -o -user lp -o -user gdm \) -ls3、查找/var目錄下最近一周內其內容修改過,同時屬主不為root,也不是postfix的文件
    find /var/ -mtime -7 -a -not \( -user root -o -user postfix \) -ls4、查找當前系統上沒有屬主或屬組,且最近一個周內曾被訪問過的文件
    find / \( -nouser -o -nogroup \) -a -atime -75、查找/etc目錄下大于1M且類型為普通文件的所有文件
    find /etc/ -size +1M -type f 

6、查找/etc目錄下所有用戶都沒有寫權限的文件
    find /etc/ -perm -2227、查找/etc目錄下至少有一類用戶沒有執行權限的文件
    find /etc/ -perm -1118、查找/etc/init.d目錄下,所有用戶都有執行權限,且其它用戶有寫權限的文件
    find /etc/init.d/ -perm -113

原創文章,作者:提著醬油瓶打醋,如若轉載,請注明出處:http://www.www58058.com/36598

(0)
提著醬油瓶打醋提著醬油瓶打醋
上一篇 2016-08-16 17:37
下一篇 2016-08-16 20:53

相關推薦

  • 文件的查找與壓縮歸檔

    文件的查找與壓縮歸檔 locate find 壓縮與歸檔 locate 主要用途 查詢系統上預建的文件索引數據庫 locate – find files by namelocate [OPTION]… PATTERN… locate查詢文件時,會去搜索/var/lib/mlocat…

    Linux干貨 2016-08-21
  • grep常見應用實例

      在我們實際應用中,正則表達式的應用是非常廣泛的,今天我就大家分享幾個比較常見的正則表達式的應用實例,不周之處,還望高人多多指點!   一:使用正則表達式搜索郵箱地址 二:使用正則表達式搜索手機號 三:使用正則表達式搜索身份證號 四:使用正則表達式取網絡配置文件中的IP地址的過程解析   一:使用正則表達式搜索郵箱地址: [r…

    系統運維 2016-08-08
  • 第15天:腳本關鍵字,函數

    http://note.youdao.com/noteshare?id=2ea9bcdf745a47bf65f0cef6e706ccaf

    Linux干貨 2016-09-06
  • Linux磁盤管理

    一、磁盤管理總體分類  1)磁盤結構  2)分區類型  3)管理分區 4)管理文件系統  5)掛載設備 6)管理虛擬內存 ……………………………………………………………………………………………………………………… 重要分類模塊詳解 ………………………………………………………………………………………………………………………

    Linux干貨 2016-08-29
  • SElinux 管理

    SELinux: Secure Enhanced Linux(安全強化的linux) SElinux安全上下文是由五個元素組成的: ①User:指示登錄系統的用戶類型,如root,user_u,system_u,多數本地進程都屬于自由(unconfined)進程 ②Role:定義文件,進程和用戶的用途:文件:object_r,進程和用戶:syste…

    Linux干貨 2016-09-26
  • 網絡及TCP

    為什么要使用分層網絡模型     降低復雜性     標準化接口     簡化模塊化設計     確保技術的互操作性     加快發展速度  &nbs…

    2017-05-08

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-08-19 15:05

    find命令是筆試中常會遇到的考點,需要多加練習,文章中命令與執行結果怎么跑到一起了,這個需要作者自己下來好好調整了。

欧美性久久久久