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
寫的很好,排版還可以在改進一下,來點例子唄,加油