馬哥教育網絡班21期第2周課程練習

1、Linux上的文件管理類命令都有哪些,其常用的使用方法及其相關示例演示。
    復制命令:cp

        cp [OPTION]… [-T] SOURCE DEST

        cp [OPTION]… SOURCE… DIRECTORY

        cp [OPTION]… -t DIRECTORY SOURCE…

        cp SRC DEST

         SRC是文件:

         如果目標不存在:新建DEST,并將SRC中內容填充至DEST中;

[root@MyServer ~]# cp /etc/inittab  /tmp
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:05 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log

        如果目錄存在:

        如果DEST是文件:將SRC中的內容覆蓋至DEST中;

        此時建議為cp命令使用-i選項;

        如果DEST是目錄:在DEST下新建與原文件同名的文件,并將SRC中內容填充至新文件中;

[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:05 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log
[root@MyServer ~]#  cp -i /etc/inittab /tmp
cp: overwrite `/tmp/inittab'? y
[root@MyServer ~]# 
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:06 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log

        cp SRC… DEST

        SRC…:多個文件

        DEST必須存在,且為目錄,其它情形均會出錯;

        cp SRC DEST

        SRC是目錄:

        此時使用選項:-r

        如果DEST不存在:則創建指定目錄,復制SRC目錄中所有文件至DEST中;

        如果DEST存在:

        如果DEST是文件:報錯

        如果DEST是目錄:

        常用選項:

        -i:交互式

        -r, -R: 遞歸復制目錄及內部的所有內容;

        -a: 歸檔,相當于-dR –preserv=all

        -d:–no-dereference –preserv=links

        –preserv[=ATTR_LIST]

        mode: 權限

        ownership: 屬主屬組

        timestamp: 時間戳

        links 鏈接

        xattr 擴展屬性

        context 安全上下文

        all 以上所有

        -p: –preserv=mode,ownership,timestamp

        -v: –verbose

        -f: –force

    移動命令:mv

       move,移動文件

       mv [OPTION]… [-T] SOURCE DEST

       mv [OPTION]… SOURCE… DIRECTORY

       mv [OPTION]… -t DIRECTORY SOURCE…

        常用選項:

           -i: 交互式

           -f: 強制

    刪除命令:rm

        remove,刪除

    rm [OPTION]… FILE…

[root@MyServer ~]# ll 
total 12
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    2 Jul 17 21:08 a.txt
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell
[root@MyServer ~]# rm a.txt 
rm: remove regular file `a.txt'? y

    常用選項:

    -i: 交互式

    -f: 強制刪除

    -r: 遞歸

        rm -rf

[root@MyServer ~]# rm -rf /tmp/aaaa/
[root@MyServer ~]# ll /tmp/
total 8
-rw-r--r--  1 root root 158 Jul 17 13:49 hosts
-rw-r--r--  1 root root 884 Jul 17 21:06 inittab
-rw-------. 1 root root   0 Dec 21  2011 yum.log
[root@MyServer ~]# ll /tmp/aaaa/
ls: cannot access /tmp/aaaa/: No such file or directory

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

[root@MyServer ~]# ll /
total 94
dr-xr-xr-x.  2 root root  4096 Sep 28  2014 bin
dr-xr-xr-x.  5 root root  1024 Apr 30  2013 boot
drwxr-xr-x  16 root root  3500 Jul 11 20:13 dev
drwxr-xr-x. 58 root root  4096 Jul 17 09:59 etc
drwxr-xr-x   4 root root  4096 Jul 16 20:05 home
dr-xr-xr-x. 10 root root  4096 Apr 30  2013 lib
dr-xr-xr-x.  8 root root 12288 Apr 30  2013 lib64
drwx------.  2 root root 16384 Dec 21  2011 lost+found
drwxr-xr-x.  2 root root  4096 Sep 23  2011 media
drwxr-xr-x.  3 root root  4096 Dec 21  2011 mnt
drwxr-xr-x.  2 root root  4096 Sep 23  2011 opt
dr-xr-xr-x  94 root root     0 Jul 11 20:13 proc
dr-xr-x---.  3 root root  4096 Jul 17 21:09 root
dr-xr-xr-x.  2 root root 12288 Apr 30  2013 sbin
drwxr-xr-x.  2 root root  4096 Dec 21  2011 selinux
drwxr-xr-x.  2 root root  4096 Sep 23  2011 srv
drwxr-xr-x  13 root root     0 Jul 11 20:13 sys
drwxrwxrwt.  3 root root  4096 Jul 17 21:11 tmp
drwxr-xr-x. 13 root root  4096 Dec 21  2011 usr
drwxr-xr-x. 17 root root  4096 Dec 21  2011 var
[root@MyServer ~]# echo $?
0

[root@MyServer ~]# ls /aaaaa
ls: cannot access /aaaaa: No such file or directory
[root@MyServer ~]# echo $?
2
[root@MyServer ~]#

    執行狀態返回值$?的數字含義為:

        0:成功執行;

        1-255:執行失敗。
3、請使用命令行展開功能來完成以下練習:

   (1)、創建/tmp目錄下的:a_c, a_d, b_c, b_d

[root@MyServer ~]# touch {a,b}_{c,d}
[root@MyServer ~]# ll
total 8
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_d
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_d
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell

   (2)、創建/tmp/mylinux目錄

[root@MyServer ~]#  mkdir -pv /tmp/mylinux/{bin,boot/grub,dev,etc/{rc.d/init.d,sysconfig/network-scripts},lib/modules,lib64,proc,sbin,sys,tmp,usr/local/{bin,sbin},var/{lock,log,run}}
mkdir: created directory `/tmp/mylinux'
mkdir: created directory `/tmp/mylinux/bin'
mkdir: created directory `/tmp/mylinux/boot'
mkdir: created directory `/tmp/mylinux/boot/grub'
mkdir: created directory `/tmp/mylinux/dev'
mkdir: created directory `/tmp/mylinux/etc'
mkdir: created directory `/tmp/mylinux/etc/rc.d'
mkdir: created directory `/tmp/mylinux/etc/rc.d/init.d'
mkdir: created directory `/tmp/mylinux/etc/sysconfig'
mkdir: created directory `/tmp/mylinux/etc/sysconfig/network-scripts'
mkdir: created directory `/tmp/mylinux/lib'
mkdir: created directory `/tmp/mylinux/lib/modules'
mkdir: created directory `/tmp/mylinux/lib64'
mkdir: created directory `/tmp/mylinux/proc'
mkdir: created directory `/tmp/mylinux/sbin'
mkdir: created directory `/tmp/mylinux/sys'
mkdir: created directory `/tmp/mylinux/tmp'
mkdir: created directory `/tmp/mylinux/usr'
mkdir: created directory `/tmp/mylinux/usr/local'
mkdir: created directory `/tmp/mylinux/usr/local/bin'
mkdir: created directory `/tmp/mylinux/usr/local/sbin'
mkdir: created directory `/tmp/mylinux/var'
mkdir: created directory `/tmp/mylinux/var/lock'
mkdir: created directory `/tmp/mylinux/var/log'
mkdir: created directory `/tmp/mylinux/var/run'

[root@MyServer ~]# tree /tmp/mylinux/
/tmp/mylinux/
├── bin
├── boot
│   └── grub
├── dev
├── etc
│   ├── rc.d
│   │   └── init.d
│   └── sysconfig
│       └── network-scripts
├── lib
│   └── modules
├── lib64
├── proc
├── sbin
├── sys
├── tmp
├── usr
│   └── local
│       ├── bin
│       └── sbin
└── var
    ├── lock
    ├── log
    └── run
24 directories, 0 files

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

文件的時間戳管理工具:

touch

文件:metadata, data

查看文件狀態:stat

三個時間戳:

access time:訪問時間,簡寫為atime,讀取文件內容

modify time: 修改時間, mtime,改變文件內容(數據)

change time: 改變時間, ctime,元數據發生改變

touch命令:

touch [OPTION]… FILE…

-a: only atime

-m: only mtime

-t STAMP:

[[CC]YY]MMDDhhmm[.ss]

-c: 如果文件不存,則不予創建

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

    命令別名(alias)

通過alias命令實現:

(1) alias

顯示當前shell進程所有可用的命令別名;

(2) alias NAME='VALUE'

定義別名NAME,其相當于執行命令VALUE;

注意:在命令行中定義的別名,僅對當前shell進程有效;如果想永久有效,要定義在配置文件中;

僅對當前用戶:~/.bashrc

對所有用戶有效:/etc/bashrc

Note: 編輯配置給出的新配置不會立即生效;

bash進程重新讀取配置文件:

source /path/to/config_file

.  /path/to/config_file

撤消別名:unalias

unalias [-a] name [name …]

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

[root@MyServer ~]# ls /var/1*[0-9]*[a-z]
ls: cannot access /var/1*[0-9]*[a-z]: No such file or directory

7、顯示/etc目錄下,以任意一個數字開頭,且以非數字結尾的文件或目錄。
[root@MyServer ~]#  ls /etc/[0-9]*[^0-9]
8、顯示/etc目錄下,以非字母開頭,后面跟了一個字母以及其它任意長度任意字符的文件或目錄。
[root@MyServer ~]# ls /etc/[^[:alpha:]][:alpha:]*
9、在/tmp目錄下創建以tfile開頭,后跟當前日期和時間的文件,文件名形如:tfile-2016-05-27-09-32-22。

[root@MyServer ~]#  touch tfile-`date +%F-%H-%M-%S`
[root@MyServer ~]# ll
total 8
-rw-r--r-- 1 root root    0 Jul 17 11:09 3
-rw-r--r-- 1 root root   27 Jul 12 20:43 aa.txt
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 a_d
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_c
-rw-r--r-- 1 root root    0 Jul 17 21:13 b_d
drwxr-xr-x 2 root root 4096 Jul 16 21:34 shell
-rw-r--r-- 1 root root    0 Jul 17 21:20 tfile-2016-07-17-21-20-46

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

[root@MyServer ~]#  mkdir /tmp/mytest1
[root@MyServer ~]# 
[root@MyServer ~]# 
[root@MyServer ~]# cp -r /etc/p*[^0-9] /tmp/mytest1
[root@MyServer ~]#

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

[root@MyServer ~]#  mkdir /tmp/mytest2
[root@MyServer ~]# 
[root@MyServer ~]# cp -r /etc/*\.d /tmp/mytest2
[root@MyServer ~]#

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

[root@MyServer ~]#  mkdir /tmp/mytest3
[root@MyServer ~]# 
[root@MyServer ~]# 
[root@MyServer ~]#  cp -r /etc/[l,m,n]*\.conf /tmp/mytest3
[root@MyServer ~]#

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

(0)
liangxiaomingliangxiaoming
上一篇 2016-07-17 21:50
下一篇 2016-07-17 21:51

相關推薦

  • VIM Note

    vim總結: 模式:編輯模式 插入模式 末行模式 內置命令行接口 打開文件 vim +# 打開文件后直接處于文件的#行行首 +/PATTER 打開文件后直接處于第一個被PATTER匹配到行的行首 + 直接處于尾行行首 模式轉換 編輯模式:默認模式,打開文件后處于編輯模式 編輯模式–>插入模式: i: insert 光標所在地方輸入 a:append 在…

    Linux干貨 2017-08-14
  • LVM詳解

    Linux的LVM詳解 LVM組成; LVM:logic volume manager .LVM即邏輯卷管理,現在使用版本為第二版,即version2 邏輯卷:pv,physical volume,即計算機上的磁盤設備,例如我的計算機上的/dev/sda3,/dev/sda5. 卷組:vg,volume group。一般由多個pv組成。 邏輯卷:lv,log…

    Linux干貨 2016-02-14
  • Linux文件查找之find命令詳解

    文件查找 文件查找就是在在文件系統上查找符合條件的文件; 文件查找分為: 實時查找:遍歷所有文件進行條件匹配 非實時查找:根據所以查找 locate: 1、查詢系統上預建的文件索引數據庫 /var/lib/mlocate/mlocate.db 2、locate屬于非實時查找,依賴于事先構建的索引; 索引的構建是在系統較為空閑時自動進行(周期性任務);管理員手…

    Linux干貨 2016-08-18
  • MySQL/MariaDB基礎性知識及DDL操作詳解

    前言 MySQL/MariaDB是一個開放源碼的小型關聯式數據庫管理系統,由于其體積小、速度快、總體擁有成本低,尤其是開放源碼這一特點,許多中小型網站為了降低網站總體擁有成本而選擇了MySQL/MariaDB作為網站數據庫。 基礎架構 MySQL核心組件 連接池:認證、線程重用、連接數限制、內存檢查、緩存 SQL接口:DDL, DML, 關系型數據庫的基本抽…

    Linux干貨 2015-05-07
  • 馬哥教育網絡班20期+第10周課程練習

     1. 請詳細描述CentOS系統的啟動流程(詳細到每個過程系統做了哪些事情) 1. 加電自檢:POST     通電后主板CMOS中的BIOS(基本輸入輸出系統)將進行硬件自檢并簡單設置,根據硬盤等     相關設備情況進入下一步   &…

    學員作品 2016-08-15
  • Linux第六周學習博客作業

    對第六周學習的內容進行總結

    2018-01-14

評論列表(1條)

  • 馬哥教育
    馬哥教育 2016-07-17 21:56

    寫的很好,排版還可以在改進一下,來點例子唄,加油

欧美性久久久久