Linux基礎知識(二)-bash基礎特性,文件管理命令

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

ls命令

列出制定目錄下的文件
ls:list

ls [OPTION]… [FILE]…

OPTION:
-a : 顯示所有文件,包括.開頭的隱藏文件
-A: 顯示除.和..意外的所有文件
-l : –long 長格式列表, 顯示文件的詳細屬性信息.
-rw-r–r–. 1 root root   8531 Sep 18 14:54 boot.log

  • : 文件類型. – , d ,b , c , l,s p
    rw-r–r– :
    rw-:文件屬主的權限
    r–:文件屬組的權限
    r–:其他用戶()的權限
    1: 數字表示文件被硬連接的次數
    root:文件的屬主
    root:文件的屬組
    8531 : 文件大小,單位是字節
    Sep 18 14:54 : 最后一次修改時間,
    boot.log: 文件名
    -h: –human–readable , 對文件大小單位換算.轉換后可能不準確(損失精度)
    -d:??茨夸涀陨矶瞧鋬炔康奈募斜?br />-r:reverse , 逆序顯示
    -R : recursive  , 遞歸顯示

文件管理工具:cp, mv, rm

cp命令

copy

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

SOURCE:源文件
DEST:目標文件

單源復制:cp [OPTION]… [-T] SOURCE DEST
如果DEST不存在:則事先創建此文件,并復制源文件的數據流至DEST中;
如果DEST存在

  • 如果DEST是非目錄文件:則覆蓋目標文件;(危險操作)

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

[root@localhost ~]# echo 1231231 >> /tmp/hello.txt
[root@localhost ~]# cat /tmp/hello.txt
1231231
[root@localhost ~]# cp /etc/fstab /tmp/hello.txt
cp: overwrite ‘/tmp/hello.txt’? y       #是否確認覆蓋?
[root@localhost ~]# cat /tmp/hello.txt

#
# /etc/fstab
# Created by anaconda on Sun Sep 18 14:47:41 2016
#
# Accessible filesystems, by reference, are maintained under '/dev/disk'
# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
#
/dev/mapper/centos-root /                       xfs     defaults        0 0
UUID=fe676930-4def-488f-ad61-eb0c8e108afc /boot                   xfs     defaults        0 0
/dev/mapper/centos-home /home                   xfs     defaults        0 0
/dev/mapper/centos-swap swap                    swap    defaults        0 0

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

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

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

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

常用選項:
-i:交互式復制,即覆蓋之前提醒用戶確認;
-f:強制覆蓋目標文件;
-r, -R:遞歸復制目錄;
-d:復制符號鏈接文件本身,而非其指向的源文件;相當于–no-dereference –preserve=links
-a:-dR –preserve=all, archive,用于實現歸檔;
–preserve=

  • mode:權限

  • ownership:屬主和屬組

  • timestamps: 時間戳

  • context:安全標簽

  • xattr:擴展屬性

  • links:符號鏈接

  • all:上述所有屬性

eg:

[root@localhost ~]# cp /etc/system-release /tmp     #/etc/system-release是快捷方式,使用cp復制到/tmp下,是把system-release指向的內容復制過來
[root@localhost ~]# cat /tmp/system-release
CentOS Linux release 7.2.1511 (Core) 
[root@localhost ~]# cp -d /etc/system-release /tmp/system.rel       #加上-d 選項 則是復制鏈接文件本身.
[root@localhost ~]# ls -l /tmp
lrwxrwxrwx. 1 root root  14 Sep 21 02:33 system.rel -> centos-release

mv命令

move
mv [OPTION]… [-T] SOURCE DEST
mv [OPTION]… SOURCE… DIRECTORY
mv [OPTION]… -t DIRECTORY SOURCE..

常用選項:
-i:交互式;
-f:force

rm命令

remove
rm [OPTION]… FILE…

常用選項:
-i:interactive 交互式,刪除前提示
-f:force       強制刪除
-r: recursive   遞歸刪除

刪除目錄:rm -rf /PATH/TO/DIR
危險操作:
rm -rf /*
rm -rf /

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

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

命令的執行狀態結果

命令的執行狀態結果

命令執行的狀態結果
bash通過狀態返回值來輸出此結果:
成功:0
失?。?-255

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

命令正常執行時,有的還回有命令返回值:
根據命令及其功能不同,結果各不相同;

引用命令的執行結果
$(COMMAND)
或`COMMAND`    反引號

[root@localhost ~]# echo $?
0
15-20-1474226454  mysysroot  x
[root@localhost ~]# mkdir /tmp/$(date +%H-%M-%S)
[root@localhost ~]# ls /tmp
15-21-12  mysysroot  x

命令行展開

~:自動展開為用戶的家目錄,或指定的用戶的家目錄;
{}:可承載一個以逗號分隔的路徑列表,并能夠將其展開為多個路徑;
例如:/tmp/{a,b} 相當于 /tmp/a /tmp/b

問題1:如何創建/tmp/x/y1, /tmp/x/y2, /tmp/x/y1/a, /tmp/x/y1/b?
問題2:如何創建a_c, a_d, b_c, b_d;
問題3:創建如下目錄結構:

            /tmp/mysysroot/
                |-- bin
                |-- etc
                |   `-- sysconfig
                |       `-- network-scripts
                |-- sbin
                |-- usr
                |   |-- bin
                |   |-- lib
                |   |-- lib64
                |   |-- local
                |   |   |-- bin
                |   |   |-- etc
                |   |   |-- lib
                |   |   `-- sbin
                |   `-- sbin
                `-- var
                    |-- cache
                    |-- log
                    `-- run

問題1:mkdir -pv /tmp/x/{y1/{a,b},y2}
問題2:mkdir -v {a,b}_{c,d}

[root@localhost ~]# mkdir -pv /tmp/x/{y1/{a,b},y2}
mkdir: created directory ‘/tmp/x/y1’
mkdir: created directory ‘/tmp/x/y1/a’
mkdir: created directory ‘/tmp/x/y1/b’
mkdir: created directory ‘/tmp/x/y2’

問題3:mkdir -pv /tmp/mysysroot/{bin,sbin,etc/sysconfig/network-scripts,usr/{bin,sbin,local/{bin,sbin,etc,lib},lib,lib64},var/{cache,log,run}}

3、請使用命令行展開功能來完成以下練習:

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

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

問題1:

[root@localhost ~]# mkdir -pv /tmp/{a,b}_{c,d}
mkdir: created directory ‘/tmp/a_c’
mkdir: created directory ‘/tmp/a_d’
mkdir: created directory ‘/tmp/b_c’
mkdir: created directory ‘/tmp/b_d’

問題2:

[root@localhost ~]# 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}}
[root@localhost ~]# 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、文件的元數據信息有哪些,分別表示什么含義,如何査看?如何修改文件的時間戳信息。

stat命令

stat – display file or file system status
顯示文件或文件系統的狀態

stat FILE…

文件:兩類數據
元數據:metadata:access(最后訪問),modify(最后修改),change(最后改變)
數據: data

時間戳:
access time:2015-12-10 16:12:22.776423693 +0800
modify time:2015-12-10 16:12:22.776423693 +0800
change time:2015-12-10 16:12:22.776423693 +0800

eg:使用stat查看文件元數據

[root@localhost ~]# echo 123 >> /tmp/functions
[root@localhost ~]# stat /tmp/functions
  File: ‘/tmp/functions’
  Size: 4           Blocks: 8          IO Block: 4096   regular file
Device: fd00h/64768d    Inode: 134         Links: 1
Access: (0644/-rw-r--r--)  Uid: (    0/    root)   Gid: (    0/    root)
Context: unconfined_u:object_r:user_tmp_t:s0
Access: 2016-09-18 15:38:47.104522265 -0400     #最近訪問
Modify: 2016-09-18 15:38:47.104522265 -0400     #最近更改:數據修改
Change: 2016-09-18 15:38:47.104522265 -0400     #最近改動:元數據修改&數據修改

touch命令

touch – change file timestamps
修改文件時間戳

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

eg:touch命令給文件指定時間戳

[root@localhost ~]# touch -m -t 0212010810.00 /tmp/functions  #修改文件Modify為2012-12-01 08:00.00

直接touch FILE… 修改文件Access,Modify,Change 時間

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

定義命令別名使用alias命令

alias命令

別名

獲取所有可用的別名定義
~]# alias
定義別名
~]# alias NAME='COMMAND'
僅對當前shell進程有效
撤銷別名:
~]# unalias NAME

eg:

[root@localhost ~]# alias
alias cp='cp -i'
alias egrep='egrep --color=auto'
alias fgrep='fgrep --color=auto'
alias grep='grep --color=auto'
alias l.='ls -d .* --color=auto'
alias ll='ls -l --color=auto'
alias ls='ls --color=auto'
alias mv='mv -i'
alias rm='rm -i'
alias which='alias | /usr/bin/which --tty-only --read-alias --show-dot --show-tilde'
[root@localhost ~]# type alias      
alias is a shell builtin
[root@localhost ~]# alias cls=clear
[root@localhost ~]# cls
[root@localhost ~]# unalias cls
[root@localhost ~]# cls
bash: cls: command not found...

在命令中引用另一個命令的執行結果,使用管道 |

管道

連接程序,實現將前一個命令的輸出直接定向給后一個程序當作輸入數據流
COMMAND1 | COMMAND2 | COMMAND3 | …

globbing:文件名通配

(整體文件名匹配,而非部分)

匹配模式:元字符
*:匹配任意長度的任意字符
pa*, *pa*, *pa, *p*a*

  • pa, paa, passwd

?:匹配任意單個字符
pa?, ??pa, p?a, p?a?

  • pa, paa, passwd

[]:匹配指定范圍內的任意單個字符
有幾種特殊格式:
[a-z], [A-Z], [0-9], [a-z0-9]
[[:upper:]]:所有大寫字母
[[:lower:]]:所有小寫字母
[[:alpha:]]:所有字母
[[:digit:]]:所有數字
[[:alnum:]]:所有的字母和數字
[[:space:]]:所有空白字符
[[:punct:]]:所有標點符號

pa[0-9][0-9], 2[0-9][0-9]
[^]:匹配指定范圍外的任意單個字符

[^[:upper:]]  所有非大寫字母
[^0-9]        所有非數字
[^[:alnum:]]  所有非字母和數字

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

[root@localhost ~]# ls -d /var/l*[0-9]*[[:lower:]]
/var/l100abc

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

ls -d /etc/[0-9]*[^0-9]

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

ls -d [^a-z][a-z]*

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

mkdir /tmp/tfile-$(date +%Y-%m-%d-%H-%M-%S )

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

cp -r /etc/p*[^0-9] /tmp/mytest1

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

cp -r /etc/*.d /tmp/mytest2

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

cp -r /etc/[lmn]*.conf /tmp/mytest3

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

(0)
luoluoluoluo
上一篇 2016-09-25
下一篇 2016-09-26

相關推薦

  • 簡述一些基礎指令

    tree命令 tree -L 1 -d /用來查看目錄結構 -L 指定層數 -d 只查看目錄 /boot 跟內核有關的文件 grub 內核和BootLoader ├── bin 存放用戶使用的基本命令(可執行程序,二進制文件) 不能單獨分區的 ├── boot 跟內核有關的文件 grub 內核和BootLoader&n…

    Linux干貨 2017-04-03
  • N26-第六周

    請詳細總結vim編輯器的使用 vim 模式化的編輯器 vim的三種模式:1.編輯模式(命令模式)                          2.輸入模式          …

    Linux干貨 2017-03-13
  • 主從模型的ipvs高可用集群實驗

    主從模型的ipvs高可用集群實驗 一.實驗拓圖 二.實驗環境 本實驗是keepalived+lvs-dr的高可用負載均衡實驗 本實驗是在虛擬機上完成,因此如上拓撲圖需要準備至少四臺虛擬機 1.各節點的時間同步 使用yum安裝chrony包,使用nat命令同步時間 2.關閉服務主機的iptables和selinux 三.實驗步驟: 1.在VS1和VS1上安裝k…

    2017-05-17
  • 抵御DDOS攻擊,iptables限制TCP連接和頻率

    cc攻擊一到就有點兵臨城下的感覺,正確的設置防護規則可以做到臨危不亂,這里給出一個iptables對ip進行連接頻率和并發限制,限制單ip連接和頻率的設置規則的介紹 #單個IP在60秒內只允許新建20個連接,這里假設web端口就是80, iptables -I  INPUT -i eth1 -p tcp -m tcp –dpo…

    系統運維 2016-05-08
  • 管道,用戶組管理

    管道 |          把左邊的命令執行結果輸送到右邊的命令作為參數執行,可以多管道多任務執行     這就是linux的哲學思想之一,鏈接程序,共同完成復雜任務     錯誤輸出默認不能通過管道…

    Linux干貨 2016-08-04
欧美性久久久久