條件判斷、文件查找與壓縮

一、條件判斷

1.條件選擇if語句
   選擇執行:
   注意:if語句可嵌套

(1).單分支
if 判斷條件:then
   條件為真的分支代碼
fi

(2).雙分支
if 判斷條件; then
   條件為真的分支代碼
else
   條件為假的分支代碼
fi

(3).多分支
if 判斷條件; then
    條件為真的分支代碼
elif 判斷條件; then
    條件為真的分支代碼
elif 判斷條件; then
    條件為真的分支代碼

else
    條件為假的分支代碼
fi

逐條件進行判斷,第一次遇為“真”條件時,執行其分支,而后結束整個if語句

if實例
根據命令的退出狀態來執行命令
if ping -c 1 -W 2 station1 &> /dev/null;then
    echo 'Station1 is UP'
elif grep "station1" ~/maintenance.txt &> /dev/null;then
    echo 'Station1 is under going maintenance'
else echo 'Station1 is unexpectedly DOWN!' exit 1
fi

2.條件判斷:case語句

case 變量引用 in
PAT1)
    分支1
    ;;
PAT2)
    分支2
    ;;

*)
    默認分支
    ;;
esac

case支持glob風格的通配符:
*: 任意長度任意字符
?: 任意單個字符
[]:指定范圍內的任意單個字符
a|b: a或b

二、文件查找

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

1.locate
查詢系統上預建的文件索引數據庫:/var/lib/mlocate/mlocate.db

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

工作特點:
查找速度快;
模糊查找;
非實時查找
搜索的是文件的全路徑,不僅僅是文件名
可能只搜索用戶具備讀取和執行權限的目錄

locate KEYWORD
選項
-i:執行區分大小寫的搜索
-n X:只列舉前X個匹配項目
-b:只匹配路徑中的基名
-c:統計符合條件的數量
-r "PATTERN":支持基礎正則表達式
例如:
搜索名稱或路徑中帶有“foo”的文件
locate foo
使用Regex來搜索以“.foo”結尾的文件
locate -r '\.foo$'

Image 001.png

Image 002.png

Image 003.png

2.find
實時查找工具,通過遍歷指定路徑完成文件查找;

工作特點:
查找速度略慢
精確查找
實時查找
可能只搜索用戶具備讀取和執行權限的目錄

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

查找條件

(1).根據文件名和inode查找:
-name "文件名稱":支持使用glob
*, ?, [], [^]
-iname "文件名稱":不區分字母大小寫
-inumn #:按inode號查找
-samefile name:相同inode號的文件
-links n :鏈接數為n的文件
-regex "PATTERN":以PATTERN匹配整個文件路徑字符串,而不僅僅是文件名稱

Image 004.png

Image 005.png

Image 006.png

(2).根據屬主、屬組查找:

-user USERNAME:查找屬主為指定用戶(UID)的文件
-group GRPNAME: 查找屬組為指定組(GID)的文件
-uidUserID:查找屬主為指定的UID號的文件
-gidGroupID:查找屬組為指定的GID號的文件
-nouser:查找沒有屬主的文件
-nogroup:查找沒有屬組的文件

Image 007.png

Image 009.png

Image 010.png

(3).根據文件類型查找:

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

Image 010.png

(4).根據文件大小來查找:

-size [+|-] #
常用單位:k, M, G
# : (#-1, #],如:6k
-# :[0,#-1], 如:-6k
+# :(#,∞), 如:+6k
Image 011.png
(5).根據時間戳:
以“天”為單位;
-atime[+|-] #,
#: [#,#+1)
+#: [#+1,∞]
-#: [0,#)
-mtime
-ctime
以“分鐘”為單位:
-amin
-mmin
-cmin
Image 012.png(6).根據權限查找:
-perm [/|-] MODE
MODE: 精確權限匹配
/MODE:任何一類(u,g,o)對象的權限中只要能一位匹配即可,或關系,+ 從centos7開始淘汰
-MODE:每一類對象都必須同時擁有指定權限,與關系
0 表示不關注
find -perm 755會匹配權限模式恰好是755的文件
只要當任意人有寫權限時,find -perm +222就會匹配
只有當每個人都有寫權限時,find -perm -222才會匹配
只有當其它人(other)有寫權限時,find -perm -002才會匹配
Image 013.png組合條件:
與:-a
或:-o
非:-not, !
德·摩根定律:
非(P 且Q) = (非P) 或(非Q)
非(P 或Q) = (非P) 且(非Q)
!A -a !B = !(A -o B)
!A -o !B = !(A -a B)

處理動作
-print:默認的處理動作,顯示至屏幕;
-ls:類似于對查找到的文件執行“ls -l”命令
-delete:刪除查找到的文件;
-flsfile:查找到的所有文件的長格式信息保存至指定文件中
-ok COMMAND {} \; 對查找到的每個文件執行由COMMAND指定的命令;對于每個文件執行命令之前,都會交互式要求用戶確認
-exec COMMAND {} \; 對查找到的每個文件執行由COMMAND指定的命令
{}: 用于引用查找到的文件名稱自身
find傳遞查找到的文件至后面指定的命令時,查找到所有符合條件的文件一次性傳遞給后面的命令
有些命令不能接受過多參數,此時命令執行可能會失敗,下面方式可規避此問題find | xargs COMMAND
排除目錄find /etc-path ‘/etc/sane.d’ -a -prune -o -name *.conf-print

find實例
搜索名為snow.png的文件
find -name snow.png

不分大小寫地搜索名為snow.png、Snow.png、SNOW.PNG等等的文件
find -iname snow.png
find / -name *.txt
find /var –name *log*
find-userjoe -groupjoe

搜索被用戶joe 以及組群joe所擁有的文件
find -user joe -not -group joe
find -user joe -o -user jane
find -not \( -user joe -o -user jane \)
find / -user joe -o -uid 500

找出/tmp目錄下,屬主不是root,且文件名不是fstab的文件
find /tmp \( -not -user root -a -not -name 'fstab' \) -ls
find /tmp -not \( -user root -o -name 'fstab' \) –ls

find實例
備份配置文件,添加.orig這個擴展名
find -name “*.conf” -exec cp {} {}.org \;
提示刪除存在時間超過3天以上的joe的臨時文件
find /tmp -ctime +3 -user joe -ok rm {} \;
在你的主目錄中尋找可被其它用戶寫入的文件
find ~ -perm -002 -exec chmodo -w {} \;
在/date目錄下查找權限為644并以.sh結尾的普通文件,將其權限設為755
find /data –type f -perm 644 -name *.sh –exec chmod 755 {} \;
查看/home下的目錄文件
find /home –type d -ls

3.Gnome搜索工具
位置->搜索文件……
圖形化搜索工具,可搜索
搜索條件:命令,內容,用戶/組群,大小,修改時間

三、壓縮與解壓縮及歸檔工具

1.compress/uncompress
  compress [-dfvcVr] [-b maxbits] [file …]
-d: 解壓縮,相當于
-c: 結果輸出至標準輸出,不刪除原文件
-v: 顯示詳情
uncompress解壓縮
zcat file.Z > file

2.gzip/gunzip
gzip[OPTION]… FILE …
-d: 解壓縮,相當于gunzip
-c: 將壓縮或解壓縮的結果輸出至標準輸出
-#:1-9,指定壓縮比,值越大壓縮比越大
zcat:不顯式解壓縮的前提下查看文本文件內容
實例:
gzip -c messages > messages.gz
gzip -c -d messages.gz > messages
zcat messages.gz > messages

3.bzip2/bunzip2/bzcat
bzip2 [OPTION]… FILE …
-k: keep, 保留原文件
-d:解壓縮
-#:1-9,壓縮比,默認為6
bzcat:不顯式解壓縮的前提下查看文本文件內容;

4.xz/unxz/xzcat
xz[OPTION]… FILE …
-k: keep, 保留原文件;
-d:解壓縮
-#:1-9,壓縮比,默認為6;
xzcat: 不顯視解壓縮的前提下查看文本文件內容;

5.zip/unzip
  zip –r sysconfigsysconfig/
  unzip sysconfig.zip
cat /var/log/messages | zip message –
unzip -p message > message

6.tar
  tar [OPTION]…
(1) 創建歸檔
tar -c -f /PATH/TO/SOMEFILE.tar FILE…
tar cf/PATH/TO/SOMEFILE.tar FILE…
(2) 查看歸檔文件中的文件列表
tar -t -f /PATH/TO/SOMEFILE.tar
(3) 展開歸檔
tar -x -f /PATH/TO/SOMEFILE.tar
tar -x -f /PATH/TO/SOMEFILE.tar -C /PATH/
結合壓縮工具實現:歸檔并壓縮
-j: bzip2, -z: gzip, -J: xz

7.cpio復制從或到文件
cpio命令是通過重定向的方式將文件進行打包備份,還原恢復的工具,它可以解壓以“.cpio”或者“.tar”結尾的文件。
cpio[選項] > 文件名或者設備名
cpio[選項] < 文件名或者設備名
選項
-o 將文件拷貝打包成文件或者將文件輸出到設備上
-i 解包,將打包文件解壓或將設備上的備份還原到系統
-t 預覽,查看文件內容或者輸出到設備上的文件內容
-v 顯示打包過程中的文件名稱。
-d 解包生成目錄,在cpio還原時,自動的建立目錄
-c 一種較新的存儲方式

實例
將etc目錄備份:
find ./etc -print | cpio -ov > etc.cpio
內容預覽
cpio –tv < etc.cpio
解包文件
cpio –iv <etc.cpio
cpio –idv < etc.cpio

條件判斷
1、寫一個腳本/root/bin/createuser.sh,
     實現如下功能:使用一個用戶名做為參數,如果指定參數的用戶存在,就顯   示其存在,否則添加之;顯示添加的用戶的id號等信息
    

#!/bin/bash
     if id $1 &> /dev/null ;then 
         echo "user $1 exists" 
     else useradd $1 && id $1
     fi

2、寫一個腳本/root/bin/yesorno.sh,提示用戶輸入yes或no,并判斷用戶輸入的是yes還是no,或是其它信息
    

#!/bin/bash
     read -p "Please input a select (yes|no):" answer
     case $answer in
     [Yy]|[Yy][Ee][Ss])
         echo -e "Your select is \033[31myes\033[0m"
         ;;
     [Nn]|[Nn][Oo])
         echo -e "Your select is \033[31mno\033[0m"
         ;;
     *)
         echo -e "This is a not good answer"
     esac
     ##!/bin/bash
     #read -p "Please input a select (yes|no):" input
     #answer=`echo $input | tr "A-Z" "a-z"` 
     #case $answer in
     #yes)
     #    echo -e "Your select is \033[31myes\033[0m"
     #    ;;
     #no)
     #    echo -e "Your select is \033[31mno\033[0m"
     #    ;;
     #*)
     #     echo -e "This is a not good answer"
     #esac

3、寫一個腳本/root/bin/filetype.sh,判斷用戶輸入文件路徑,顯示其文件類型(普通,目錄,鏈接,其它文件類型)
   

  #!/bin/bash
     read -p "Please input a filename:" filename
     if test -e $filename;then
         if test -f $filename;then
             echo "regular file"
         elif test -d $filename;then
             echo "dirctory"
         elif test -h $filename;then
             echo "link"
         else
             echo "other"
         fi
    else 
        echo "$filename not exist"
    fi

4、寫一個腳本/root/bin/checkint.sh,判斷用戶輸入的參數是否為正整數
   

 #!/bin/bash
    if [[ $1 =~ ^0*[1-9][0-9]*$ ]];then
        echo "int"
    else
        echo "not int"
    fi
     
    ##!/bin/bash
    #if expr $1 + 0 &> /dev/null;then  
    #    echo "int"
    #else
    #    echo "not int"
    #fi

    
文件查找
1、查找/var目錄下屬主為root,且屬組為mail的所有文件
     find /var -user root -group mail
2、查找/var目錄下不屬于root、lp、gdm的所有文件
     find /var -not \( -user root -o -user lp -o -user gdm \)
3、查找/var目錄下最近一周內其內容修改過,同時屬主不為root,也不是postfix的文件
     find /var -mtime -7 -not \( -user root -o -user postfix \)
4、查找當前系統上沒有屬主或屬組,且最近一個周內曾被訪問過的文件
     find / -nouser -o -nogroup -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

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

(0)
anonymousanonymous
上一篇 2016-08-15 11:58
下一篇 2016-08-15 11:59

相關推薦

  • 基于iptables mangle的lvs && lvs的持久連接

    一、lvs-dr類型:也稱direct routing,簡稱為g(gatewaying);配置lvs-dr基于iptables mangle的實現方式  實驗圖:  地址規劃:    VIP: 172.16.2.100    DIP: 172.16.2.13    RIP1:17…

    Linux干貨 2015-06-30
  • bash的重定向

    一、簡介         bash的數據流重定向(redirect)是將程序的執結果重新定向到另一文件或者設備?;蛘甙岩晃募囟ㄏ蚪o一程序作為數據來源。默認情況下,命令的執行結果顯示在屏幕上。文件系統中,分為:標準輸入,標準輸出,錯誤輸出。 二、用法   &n…

    Linux干貨 2015-08-11
  • IP地址之IPv6

    一、IPv6概述   目前使用的IP地址都是IPv4版本,之所以開發出IPv6版本主要是基于以下原因:     1、IPv4地址空間不足,分配不合理;     2、IPv4頭部太過于復雜;     3、使用IPv4使得路由器及主機配置復雜;     4、對于IPv4重新…

    Linux干貨 2016-01-13
  • Trap命令簡介

     Trap命令簡介     一、基本概念  trap是一個shell內建命令,它用來在腳本中指定信號如何處理。比如,按Ctrl+C會使腳本終止執行,實際上系統發送了SIGINT信號給腳本進程,SIGINT信號的默認處理方式就是退出程序。如果要在Ctrl +C不退出程序,那么就得使用trap命令來指定一下SIGINT的處…

    Linux干貨 2015-05-11
  • 正則表達式

    grep:Global search REgular expression and Print out the line         文本搜索工具,根據用戶指定的”模式“對目標文本逐行進行匹配檢查;打印匹配到的行        模式:由正則表達式字符及文本字符所編寫的過濾條件…

    Linux干貨 2016-08-08
  • 再不自動化就晚啦!優云教你4步打造基于CentOS的產品鏡像

    隨著Linux程序的增多,軟件的安裝過程中經常出現如下問題: 1、硬件配置類似或者相同時,批量安裝系統和軟件,希望實現自動化安裝,減少安裝時間和人為出錯。 2、工程實施人員在不同客戶現場進行系統和軟件安裝(硬件配置不同),由于硬件有差別,不容易實現自動化。 筆者針對以上場景,從提高生產效率,減少誤操作的立場,提出如下解決方案,希望能達到拋磚引玉的目的,并能與…

    系統運維 2016-07-16

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-08-19 09:17

    總結的很詳細,腳本那就是需要多謝多練,find命令對我們來說很重要的,也是個很有用的工具,所以需要好好練習哦

欧美性久久久久