The second week’s homework

一.linux上的文件管理類命令都有哪些,其常用的使用方法及其相關示例演示。

Linux 文件與目錄管理

我們知道Linux的目錄結構為樹狀結構,最頂級的目錄為根目錄 /。

其他目錄通過掛載可以將它們添加到樹中,通過解除掛載可以移除它們。

首先需要知道什么是絕對路徑與相對路徑。

  • 絕對路徑

    路徑的寫法,由根目錄 / 寫起,例如: /usr/share/doc 這個目錄。

  • 對路徑

    路徑的寫法,不是由 / 寫起,例如由 /usr/share/doc 要到 /usr/share/man 底下時,可以寫成: cd ../man 這就是相對路徑的寫法啦!

    Linux文件系統規范

    1、文件名名稱嚴格區分字符大小寫;

    2、文件可以使用除/以外任意字符;

    3、文件名長度不能超過255字符;

    4、以.開頭的文件為隱藏文件;

            .: 當前目錄;

           ..: 當前目錄的上一級目錄;

    補充bash基礎特性之一:

       命令補全:

     給定的打頭字符串如果能惟一標識某命令程序文件,則直接補全;

     不能惟一標識某命令程序文件,再擊tab鍵一次,會給出列表;

        路徑補全:

    在給定的起始路徑下,以對應路徑下的打頭字串來逐一匹配起始路徑下的每個文件:

      tab:

    如果能惟一標識,則直接補全;

    否則,再一次tab,給出列表;


處理目錄的常用命令

接下來我們就來看幾個常見的處理目錄的命令吧:

  • ls: 列出目錄

  • cd:切換目錄

  • pwd:顯示目前的目錄

  • mkdir:創建一個新的目錄

  • rmdir:刪除一個空的目錄

  • cp: 復制文件或目錄

  • rm: 移除文件或目錄

可以使用 man [命令] 來查看各個命令的使用文檔,如 :man cp。

ls (列出目錄)

在Linux系統當中, ls 命令可能是最常被運行的。

語法:

ls [OPTION]... [FILE]...

選項與參數:

  • -a :全部的文件,連同隱藏檔( 開頭為 . 的文件) 一起列出來(常用)

  • -d :僅列出目錄本身,而不是列出目錄內的文件數據(常用)

  • -l :長數據串列出,包含文件的屬性與權限等等數據;(常用)

  • -h, –human-readable:對文件大小單位換算;換算后結果可能會非精確值;

  • -r: reverse, 逆序顯示;

  • -R: recursive,遞歸顯示;

[root@localhost ~]# ls -l /etc/fstab
-rw-r--r--. 1 root root 500 Nov 12 01:40 /etc/fstab

             -:文件類型,-, d, b, c, l, s, p
             rw-r–r–            

            rw-:文件屬主的權限;             

            r–:文件屬組的權限;             

            r–:其它用戶(非屬主、屬組)的權限;             

            1:數字表示文件被硬鏈接的次數;             

            root:文件的屬主;             

            root:文件的屬組;             

            500:數字表示文件的大小,單位是字節;             

            Nov   12   01:40:文件最近一次被修改的時間;             

             /etc/fstab:文件名

cd (切換目錄)

cd是Change Directory的縮寫,這是用來變換工作目錄的命令。

語法:

 cd [相對路徑或絕對路徑]
#使用 mkdir 命令創建w3cschool.cc目錄
[root@www ~]# mkdir w3cschool.cc 

#使用絕對路徑切換到w3cschool.cc目錄
[root@www ~]# cd /root/w3cschool.cc/ 

#使用相對路徑切換到w3cschool.cc目錄
[root@www ~]# cd ./w3cschool.cc/ 

# ~表示回到自己的家目錄,亦即是 /root 這個目錄
[root@www w3cschool.cc]# cd ~ 
           
# 表示去到目前的上一級目錄,亦即是 /root 的上一級目錄的意思;
[root@www ~]# cd ..

         cd ~USERNAME:切換至指定用戶的家目錄;

         cd -:在上一次所在目錄與當前目錄之間來回切換;

pwd (顯示目前所在的目錄)

pwd是Print Working Directory的縮寫,也就是顯示目前所在目錄的命令。

[root@www ~]# pwd [-P]
選項與參數:
-P  :顯示出確實的路徑,而非使用連結 (link) 路徑。
 
范例:單純顯示出目前的工作目錄:
[root@www ~]# pwd
/root   <== 顯示出目錄啦~ 

范例:顯示出實際的工作目錄,而非連結檔本身的目錄名而已
[root@www ~]# cd /var/mail   <==注意,/var/mail是一個連結檔
[root@www mail]# pwd
/var/mail         <==列出目前的工作目錄
[root@www mail]# pwd -P
/var/spool/mail   <==怎么回事?有沒有加 -P 差很多~
[root@www mail]# ls -ld /var/mail
lrwxrwxrwx 1 root root 10 Sep  4 17:54 /var/mail -> spool/mail
# 看到這里應該知道為啥了吧?因為 /var/mail 是連結檔,連結到 /var/spool/mail 
# 所以,加上 pwd -P 的選項后,會不以連結檔的數據顯示,而是顯示正確的完整路徑啊!

mkdir (創建新目錄)

如果想要創建新的目錄的話,那么就使用mkdir (make directory)吧。

語法:

mkdir [-mp] 目錄名稱

選項與參數:

  • -m :配置文件的權限喔!直接配置,不需要看默認權限 (umask) 的臉色~

  • -p :幫助你直接將所需要的目錄(包含上一級目錄)遞回創建起來!

范例:請到/tmp底下嘗試創建數個新目錄看看:

[root@www ~]# cd /tmp
[root@www tmp]# mkdir test    <==創建一名為 test 的新目錄
[root@www tmp]# mkdir test1/test2/test3/test4
mkdir: cannot create directory `test1/test2/test3/test4': 
No such file or directory       <== 沒辦法直接創建此目錄啊![
root@www tmp]# mkdir -p test1/test2/test3/test4

加了這個 -p 的選項,可以自行幫你創建多層目錄!

范例:創建權限為rwx–x–x的目錄

[root@www tmp]# mkdir -m 711 test2 
[root@www tmp]# ls -l 
drwxr-xr-x  3 root  root 4096 Jul 18 12:50 test 
drwxr-xr-x  3 root  root 4096 Jul 18 12:53 test1 
drwx--x--x  2 root  root 4096 Jul 18 12:54 test2

上面的權限部分,如果沒有加上 -m 來強制配置屬性,系統會使用默認屬性。

如果我們使用 -m ,如上例我們給予 -m 711 來給予新的目錄 drwx–x–x 的權限。

rmdir (刪除空的目錄)

語法:

 rmdir [-p] 目錄名稱

選項與參數:

  • -p :連同上一級『空的』目錄也一起刪除

刪除 w3cschool.cc 目錄

[root@www tmp]# rmdir w3cschool.cc/

范例:將於mkdir范例中創建的目錄(/tmp底下)刪除掉!

[root@www tmp]# ls -l   <==看看有多少目錄存在?
drwxr-xr-x  3 root  root 4096 Jul 18 12:50 test
drwxr-xr-x  3 root  root 4096 Jul 18 12:53 test1
drwx--x--x  2 root  root 4096 Jul 18 12:54 test2
[root@www tmp]# rmdir test   <==可直接刪除掉,沒問題
[root@www tmp]# rmdir test1  <==因為尚有內容,所以無法刪除!
rmdir: `test1': Directory not empty
[root@www tmp]# rmdir -p test1/test2/test3/test4
[root@www tmp]# ls -l        <==您看看,底下的輸出中test與test1不見了!
drwx--x--x  2 root  root 4096 Jul 18 12:54 test2

利用 -p 這個選項,立刻就可以將 test1/test2/test3/test4 一次刪除。

不過要注意的是,這個 rmdir 僅能刪除空的目錄,你可以使用 rm 命令來刪除非空目錄。

cp (復制文件或目錄)

cp 即拷貝文件和目錄。

語法:

單源復制:cp [OPTION]... [-T] SOURCE DEST
多源復制:cp [OPTION]... SOURCE... DIRECTORY         
        cp [OPTION]... -t DIRECTORY SOURCE...

單源復制:cp [OPTION]… [-T] SOURCE DEST 

    如果DEST不存在:則事先創建此文件,并復制源文件的數據流至DEST中;     

    如果DEST存在:     

        如果DEST是非目錄文件:則覆蓋目標文件;     

        如果DEST是目錄文件:則先在DEST目錄下創建一個與源文件同名的文件,并復制其數據流; 

多源復制:cp [OPTION]… SOURCE… DIRECTORY                   

                  cp [OPTION]… -t DIRECTORY SOURCE…     

    如果DEST不存在:錯誤;      如果DEST存在:     

    如果DEST是非目錄文件:錯誤;     

    如果DEST是目錄文件:分別復制每個文件至目標目錄中,并保持原名;

選項與參數:

  • -a:相當於 -pdr 的意思,至於 pdr 請參考下列說明;(常用)

  • -d:若來源檔為連結檔的屬性(link file),則復制連結檔屬性而非文件本身;

  • -f:為強制(force)的意思,若目標文件已經存在且無法開啟,則移除后再嘗試一次;

  • -i:若目標檔(destination)已經存在時,在覆蓋時會先詢問動作的進行(常用)

  • -l:進行硬式連結(hard link)的連結檔創建,而非復制文件本身;

  • -p:連同文件的屬性一起復制過去,而非使用默認屬性(備份常用);

  • -r:遞回持續復制,用於目錄的復制行為;(常用)

  • -s:復制成為符號連結檔 (symbolic link),亦即『捷徑』文件;

  • -u:若 destination 比 source 舊才升級 destination !

  • 用 root 身份,將 root 目錄下的 .bashrc 復制到 /tmp 下,并命名為 bashrc

    [root@www ~]# cp ~/.bashrc /tmp/bashrc 
    [root@www ~]# cp -i ~/.bashrc /tmp/bashrc 
    cp: overwrite `/tmp/bashrc'? n  <==n不覆蓋,y為覆蓋

    rm (移除文件或目錄)

    語法:

     rm [-fir] 文件或目錄

    選項與參數:

    • -f :就是 force 的意思,忽略不存在的文件,不會出現警告信息;

    • -i :互動模式,在刪除前會詢問使用者是否動作

    • -r :遞回刪除啊!最常用在目錄的刪除了!這是非常危險的選項?。。?/span>

    將剛剛在 cp 的范例中創建的 bashrc 刪除掉!

    [root@www tmp]# rm -i bashrc 
    rm: remove regular file `bashrc'? y

    如果加上 -i 的選項就會主動詢問喔,避免你刪除到錯誤的檔名!

    *注意:所有不用的文件建議不要直接刪除,而是移動至某個專用目錄;(模擬回收站)

    切勿使用~]#rm -fr /*

    mv (移動文件與目錄,或修改名稱)

    語法

    [root@www ~]# mv [-fiu] source destination 
    [root@www ~]# mv [options] source1 source2 source3 .... directory

    選項與參數:

    • -f :force 強制的意思,如果目標文件已經存在,不會詢問而直接覆蓋;

    • -i :若目標文件 (destination) 已經存在時,就會詢問是否覆蓋!

    • -u :若目標文件已經存在,且 source 比較新,才會升級 (update)

    復制一文件,創建一目錄,將文件移動到目錄中

    [root@www ~]# cd /tmp 
    [root@www tmp]# cp ~/.bashrc bashrc 
    [root@www tmp]# mkdir mvtest 
    [root@www tmp]# mv bashrc mvtest

    將某個文件移動到某個目錄去,就是這樣做!

    將剛剛的目錄名稱更名為 mvtest2

    [root@www tmp]# mv mvtest mvtest2

    Linux 文件內容查看

    Linux系統中使用以下命令來查看文件的內容:

    • cat  由第一行開始顯示文件內容

    • tac  從最后一行開始顯示,可以看出 tac 是 cat 的倒著寫!

    • nl   顯示的時候,順道輸出行號!

    • more 一頁一頁的顯示文件內容

    • less 與 more 類似,但是比 more 更好的是,他可以往前翻頁!

    • head 只看頭幾行

    • tail 只看尾巴幾行

    你可以使用 man [命令]來查看各個命令的使用文檔,如 :man cp。

    cat

    由第一行開始顯示文件內容

    語法:

    cat [-AbEnTv]

    選項與參數:

    • -A :相當於 -vET 的整合選項,可列出一些特殊字符而不是空白而已;

    • -b :列出行號,僅針對非空白行做行號顯示,空白行不標行號!

    • -E :將結尾的斷行字節 $ 顯示出來;

    • -n :列印出行號,連同空白行也會有行號,與 -b 的選項不同;

    • -T :將 [tab] 按鍵以 ^I 顯示出來;

    • -v :列出一些看不出來的特殊字符

    檢看 /etc/issue 這個文件的內容:

    [root@www ~]# cat /etc/issue 
    CentOS release 6.4 (Final)
    Kernel \r on an \m

    tac

    tac與cat命令剛好相反,文件內容從最后一行開始顯示,可以看出 tac 是 cat 的倒著寫!如:

    [root@www ~]# tac /etc/issue 
    Kernel \r on an \m 
    CentOS release 6.4 (Final)

    nl

    顯示行號

    語法:

    nl [-bnw] 文件

    選項與參數:

    • -b :指定行號指定的方式,主要有兩種:
      -b a :表示不論是否為空行,也同樣列出行號(類似 cat -n);
      -b t :如果有空行,空的那一行不要列出行號(默認值);

    • -n :列出行號表示的方法,主要有三種:
      -n ln :行號在螢幕的最左方顯示;
      -n rn :行號在自己欄位的最右方顯示,且不加 0 ;
      -n rz :行號在自己欄位的最右方顯示,且加 0 ;

    • -w :行號欄位的占用的位數。

    范例一:用 nl 列出 /etc/issue 的內容

    [root@www ~]# nl /etc/issue     
       1  CentOS release 6.4 (Final)     
       2  Kernel \r on an \m

    more

    一頁一頁翻動

    [root@www ~]# more /etc/man.config
    #
    # Generated automatically from man.conf.in by the
    # configure script.
    #
    # man.conf from man-1.6d
    ....(中間省略)....
    --More--(28%)  <== 重點在這一行喔!你的光標也會在這里等待你的命令

    在 more 這個程序的運行過程中,你有幾個按鍵可以按的:

    • 空白鍵 (space):代表向下翻一頁;

    • Enter         :代表向下翻『一行』;

    • /字串         :代表在這個顯示的內容當中,向下搜尋『字串』這個關鍵字;

    • :f            :立刻顯示出檔名以及目前顯示的行數;

    • q             :代表立刻離開 more ,不再顯示該文件內容。

    • b 或 [ctrl]-b :代表往回翻頁,不過這動作只對文件有用,對管線無用。

    less

    一頁一頁翻動,以下實例輸出/etc/man.config文件的內容

    [root@www ~]# less /etc/man.config
    #
    # Generated automatically from man.conf.in by the
    # configure script.
    #
    # man.conf from man-1.6d
    ....(中間省略)....
    :   <== 這里可以等待你輸入命令!

    less運行時可以輸入的命令有:

    • 空白鍵    :向下翻動一頁;

    • [pagedown]:向下翻動一頁;

    • [pageup]  :向上翻動一頁;

    • /字串     :向下搜尋『字串』的功能;

    • ?字串     :向上搜尋『字串』的功能;

    • n         :重復前一個搜尋 (與 / 或 ? 有關!)

    • N         :反向的重復前一個搜尋 (與 / 或 ? 有關!)

    • q         :離開 less 這個程序;

    head取出文件前面幾行

    語法:

    head [-n number] 文件

    選項與參數:

    • -n :后面接數字,代表顯示幾行的意思

    [root@www ~]# head /etc/man.config

    默認的情況中,顯示前面 10 行!若要顯示前 20 行,就得要這樣:

    [root@www ~]# head -n 20 /etc/man.config

    tail(取出文件后面幾行)

    語法:

    tail [-n number] 文件

    選項與參數:

    • -n :后面接數字,代表顯示幾行的意思

    • -f :表示持續偵測后面所接的檔名,要等到按下[ctrl]-c才會結束tail的偵測

    [root@www ~]# tail /etc/man.config 
    # 默認的情況中,顯示最后的十行!若要顯示最后的 20 行,就得要這樣:
    [root@www ~]# tail -n 20 /etc/man.config

    二.bash的工作特性之命令執行狀態返回值和命令行展開所所涉及的內容及其示例演示。

    •   bash的工作基礎特性之:命令執行的狀態返回值

               bash通過狀態返回值來輸出此結果:    

                 成功:0   

                 失?。?-255           

        命令執行完成之后,其狀態返回值保存于bash的特殊變量$?中;        

        命令正常執行時,有的還回有命令返回值:        

        根據命令及其功能不同,結果各不相同;        

        引用命令的執行結果:         

                 $(COMMAND)         

                 或`COMMAND`

        bash的基于特性:引用

                 強引用:''

                 弱引用:""

                 命令引用:“

        bash基礎特性:快捷鍵
                 Ctrl+a:跳轉至命令行行首

                 Ctrl+e:跳轉至命令行行尾

                 Ctrl+u:刪除行首至光標所在處之間的所有字符;

                 Ctrl+k:刪除光標所在處至行尾的所有字符;

                Ctrl+l:清屏,相當于clear

    [root@localhost ~]# cat /etc/issue
    \S
    Kernel \r on an \m 

    [root@localhost ~]# echo $?                    #上一條命令正確返回值‘0’0
    [root@localhost ~]# cat /etc/issue1
    cat: /etc/issue1: No such file or directory
    [root@localhost ~]# echo $?                    #上一條命令執行錯誤返回值‘1’1

    •    bash的工作基礎特性之:命令行展開

            ~:自動展開為用戶的家目錄,或指定的用戶的家目錄;                  

            {}:可承載一個以逗號分隔的路徑列表,并能夠將其展開為多個路徑;           

        例如:/tmp/{a,b} 相當于 /tmp/a /tmp/b

    [root@localhost log]# cd /var/log
    [root@localhost log]# cd ~
    [root@localhost ~]#                    #切換至root用戶的家目錄
    [root@localhost ~]# mkdir -pv /tmp/{a,b} 
    mkdir: created directory ‘/tmp/a’      #在tmp目錄下創建a目錄
    mkdir: created directory ‘/tmp/b’      #在tmp目錄下創建b目錄

    三. 文件的元數據信息有那些,分別表示什么含義,如何查看?如何修改文件的時間戳信息。

    • 可以用stat(display file or file system status)來查看文件或文件系統的狀態: 

             文件:兩類數據                 

                    元數據:metadata                 

                    數據: data

    [root@localhost ~]# stat /etc/issue   
    File: ‘/etc/issue’   
    Size: 23         Blocks: 8          IO Block: 4096   regular file 
    Device: fd00h/64768d Inode: 16785283    Links: 1 
    Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root) 
    Access: 2016-12-12 01:13:26.156010051 +0800 
    Modify: 2015-12-09 17:59:15.000000000 +0800 
    Change: 2016-11-04 01:40:25.995028705 +0800  Birth: -

          File:文件名;Blocks:塊;IO Block:IO塊;Device:設備;Access(第一個):權限;Uid:創建者id;Gid:歸屬組id;Access(第二個):最近訪問;modify:最近修改;change:最近改動

    • 可以用touch (change file timestamps)命令來修改文件的時間戳

       一是用于把已存在文件的時間標簽更新為系統當前的時間(默認方式),它們的數據將原封不動地保留下來;         

      二是用來創建新的空文件。

    touch [OPTION]… FILE…

        選項和參數:

                 -c: 指定的文件路徑不存在時不予創建;

         -a: 僅修改access time;

        -m:僅修改modify time;

        -t STAMP

                [[CC]YY]MMDDhhmm[.ss]

    touch [OPTION]… FILE…選項和參數: -c: 指定的文件路徑不存在時不予創建; -a: 僅修改access time; -m:僅修改modify time; -t STAMP [[CC]YY]MMDDhhmm[.ss]

    [root@localhost ~]# touch test.xxx                 #將test.php的檔案時間改為,當前時間,文件不存在建之 
    [root@localhost ~]# touch -c -t 05061803 test.xxx  #將檔案時間改為,5月6日18點3分 
    [root@localhost ~]# touch -r abc.xxx test.xxx      #將test.php文件的時間改成跟abc.xxx一樣

    四.如何定義一個命令別名,如何在命令中引用另一個命令的執行結果?

    •   alias  命令別名

         獲取所有可用別名的定義:                   

                 ~]# alias               

          定義別名:                   

                 ~]# alias NAME='COMMAND'                   

          注意:僅對當前shell進程有效               

          撤銷別名:                   

                ~]# unalias NAME

    [root@localhost ~] alias ty=ls        #為ls設置別名[
    root@localhost ~] ty -al             #別名
    drwxr-xr-x 4 tnak tnak 4096  4月 27 14:20 .
    drwxr-xr-x 4 root root 4096  4月 27 12:34 ..
    -rw-r--r-- 1 root root  255  4月 26 12:44 abc.sh
    drwxr-xr-x 2 root root 4096  4月 26 13:44 ar_test 

    [root@localhost ~] alias yy='ls -ar'  #設置別名,可以是命令帶參數

    五.練習

    1.創建/tmp目錄下的:a_c,a_d,b_c,b_d

    [root@localhost ~]# mkdir /tmp/{a,b}_{c,d}
    [root@localhost ~]# ls /tmp
    a    hogsuspend
    a_c  systemd-private-2d996ddd27de4e6b929d5c64200c9058-cups.service-ymoNeI
    a_d  systemd-private-2d996ddd27de4e6b929d5c64200c9058-vmtoolsd.service-zteDS8
    b    systemd-private-f96fe84bd1d54e52912dc82f3f0ba9b0-cups.service-N44lfN
    b_c  systemd-private-f96fe84bd1d54e52912dc82f3f0ba9b0-vmtoolsd.service-NmTZSh
    b_d

    2.創建/tmp/mylinux如下目錄:

    [root@localhost ~]# mkdir -p /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scrips},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}} 
    [root@localhost ~]# tree /tmp/mylinux           #tree以樹狀圖列出目錄的內容 /tmp/mylinux 
    ├── bin 
    ├── boot 
    │   └── grub 
    ├── dev 
    ├── etc 
    │   ├── rc.d 
    │   │   └── init.d 
    │   └── sysconfig 
    │       └── network-scrips 
    ├── lib 
    │   └── modules 
    ├── lib64 
    ├── proc 
    ├── sbin 
    ├── sys 
    ├── tmp 
    ├── usr 
    │   └── local 
    │       ├── bin 
    │       └── sbin 
    └── var     
    ├── lock     
    ├── log     
    └── run 
    24 directories, 0 files

    3.    顯示/var目錄下所有以l開頭,以一個小寫字母結尾,且中間至少出現一位數字(可以有其他字符)的文件或目錄。

    [root@localhost ~]# ls -d /var/l?[a-z]
    /var/lib  /var/log

    4.    顯示/etc目錄下,以任何一個數字開頭,且以非數字結尾的文件或目錄。

    [root@localhost ~]# ls -d /etc/[0-9]*[^[:digit:]]

    5.    顯示/etc目錄下,以非字母開頭,后面跟了一個字母以及其他任意長度任意字符的文件或目錄。

    [root@localhost ~]# ls /etc/[^[:alpha:]][a-z]*

    6.    在/tmp目錄下創建以tfile開頭,后跟當前日期和時間的文件,文件名形如:tfile=2016-05-27-09-32-22.

    [root@localhost ~]# touch /tmp/tfile-$(date +%F-%H-%M-%S)
    [root@localhost ~]# ls /tmp
    hogsuspend  mylinux  tfile-2016-12-12-21-10-55

    7.    復制/etc目錄下所有以p開頭,以非數字結尾的文件或目錄到/tmp/mytest1目錄中。

    [root@localhost ~]# mkdir /tmp/mytest1           #創建目錄mytest1
    [root@localhost ~]# cp -r /etc/p*[^0-9] /tmp/mytest1
    cp: overwrite ‘/tmp/mytest1/pam.d/config-util’? y
    cp: overwrite ‘/tmp/mytest1/pam.d/other’? y            #后面還有很多文件,暫不一一列舉
    [root@localhost ~]# ls /tmp/mytest1/pam.d    
    pbm2ppa.conf  plymouth      popt.d   prelink.conf.d  profile.d  
    purple                                                 #和CP的結果一樣,暫不一一列舉

    8.    復制/etc目錄下所有以.d結尾的或目錄至/tmp/mytest2目錄中。

    [root@localhost ~]# mkdir /tmp/mytest2          #創建目錄mytest2
    [root@localhost ~]# cp -r /etc/*.d /tmp/mytest2
    [root@localhost ~]# ls /tmp/mytest2
    bash_completion.d  ipsec.d         profile.d      rwtab.d
    binfmt.d           ld.so.conf.d    rc0.d          sane.d
    chkconfig.d        libibverbs.d    rc1.d          setuptool.d
    cron.d             logrotate.d     rc2.d          statetab.d
    depmod.d           modprobe.d      rc3.d          sudoers.d
    dnsmasq.d          modules-load.d  rc4.d          sysctl.d
    dracut.conf.d      my.cnf.d        rc5.d          tmpfiles.d
    exports.d          oddjobd.conf.d  rc6.d          usb_modeswitch.d
    gdbinit.d          pam.d           rc.d           xinetd.d
    grub.d             popt.d          request-key.d  yum.repos.d
    init.d             prelink.conf.d  rsyslog.d

    9.    復制/etc目錄下所有以l或m或n開頭,以.conf結尾的文件至/tmp/mytest3目錄中。

    [root@localhost ~]# mkdir /mytest3                 #在/目錄下創建目錄mytest3
    [root@localhost ~]# cp -r /etc/[lmn]*.conf /tmp/mytest3
    cp: target ‘/tmp/mytest3’ is not a directory       #如上,未在/tmp/創建目錄mytest3,所以在COPY的時候提示目標不是目錄
    [root@localhost ~]# mkdir /tmp/mytest3             #在/tmp/下創建mytest3目錄
    [root@localhost ~]# cp -r /etc/[lmn]*.conf /tmp/mytest3    #復制成功
    [root@localhost ~]# ls /tmp/mytest3
    ld.so.conf     locale.conf     mke2fs.conf    nsswitch.conf
    libaudit.conf  logrotate.conf  mtools.conf    numad.conf
    libuser.conf   man_db.conf     nfsmount.conf

    補充說明globbing(文件名通配)的格式

         *:匹配任意長度的任意字符;             ?:匹配任意單個字符            []:匹配制定范圍內的任意單個字符        [^]:匹配制定范圍外的任意單個字符

    特殊格式:

         [a-z],[A-Z],[0-9],[a-z 0-9]   他們不區分大小寫

         [:upper:]:所有大寫字母           [:lower:]:所有小寫字母         [:alpha:]:所有字母               [:digit:]:所有數字   

         [:alnum:]:所有字母和數字       [:space:]:所有空白字符       [:punct:]:所有標點符號

      示例:2[0-9][0-9] :表示200-299

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

(0)
小飝小飝
上一篇 2016-12-12
下一篇 2016-12-12

相關推薦

  • 系統排錯——如何修復和保護你的系統

    作業 1、破解root口令,并為grub設置保護功能 開機啟動時按e進入grub菜單,然后按a 編輯當前菜單的kernel選項,在后面追加1,s,S,single中的任意一個,然后回車,輸入b鍵啟動 進入了單用戶模式,可以直接修改root密碼 如何為grub設置保護功能: (1)、首先生成grub的md5密碼 (2)、修改grub.conf文件 (3)、重啟…

    Linux干貨 2016-09-12
  • 系統啟動及內核管理

    一、知識整理 1、nohup 命令:不掛斷地運行命令,遠程連接當斷網或斷開shell時還可以繼續運行。無論是否將nohup命令的輸出重定向到終端,輸出都將附加到當前目錄下的nohup.out文件中,如果當前不可寫,則重定向到家目錄nohup.out文件,除非定義了輸出文件。 nohup COMMAND 輸出重定向至文件 nohup COMMAND &…

    Linux干貨 2016-09-19
  • tomcat基礎-如何給Tomcat前端加反向代理服務器

    Tomcat可以做為反向代理服務器的組件有很多,例如使用nginx,如果使用nginx,Tomcat就只能使用http連接器,另外一種是apache。如果是使用httpd,Tomcat兩種連接器都能發揮作用,例如可以使用http連接器,也可以使用ajp連接器,

    Linux干貨 2018-03-19
  • 馬哥教育網絡班21期+第4周作業

    1、復制/etc/skel目錄為/home/tuser1,要求/home/tuser1及其內部文件的屬組和其它用戶均沒有任何訪問權限。 [root@localhost ~]# cp -r /etc/skel /home/ && mv /home/skel&nbsp…

    Linux干貨 2016-08-02
  • 分區管理和文件系統

    管理分區:        lsblk           列出塊設備        fdisk          創建MBR 分區      &nbs…

    Linux干貨 2017-03-11
  • Linux的任務計劃

    Linux的任務計劃         我們在使用系統的過程中,經常需要在以后的某個時間點執行一個任務,而我們又不在機器旁邊的時候,比如在半夜時服務器訪問的用戶很少,寬帶資源很充足的時候,要去鏡像軟件包、重啟服務器(雖然Linux很穩定)等,或者需要服務器在每天的特定時間去備份數據…

    2017-03-19

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-12-16 23:41

    贊~總結的不錯~注意下整體排版的風格~繼續加油~

欧美性久久久久