1、Linux上的文件管理類命令,其常用的使用方法及其相關示例演示。
ls:顯示目錄內容
ls [OPTION]... [FILE]...
-a: 顯示所有文件,包括隱藏文件;
-A:顯示除.和..之外的所有文件;
-l: --long, 長格式列表,即顯示文件的詳細屬性信息;
-h, --human-readable:對文件大小單位換算;換算後結果可能會非精確值;
-d:查看目錄自身而非其內部的文件列表;
-r: reverse, 逆序顯示;
-R: recursive,遞歸顯示;
示例:
# ls -l
total 32
lrwxrwxrwx. 1 root root 7 May 7 05:46 bin -> usr/bin
dr-xr-xr-x. 4 root root 4096 May 7 05:54 boot
drwxr-xr-x. 20 root root 3120 May 23 05:06 dev
drwxr-xr-x. 75 root root 8192 May 23 14:46 etc
。。。略 。。。
cd:將當前工作目錄切換至指定目錄
cd [/PATH/TO/SOMEDIR]
cd: 切換回家目錄;
cd ~:切換回自己的家目錄
cd ~USERNAME:切換至指定用戶的家目錄;
cd -:在上一次所在目錄與當前目錄之間來回切換;
相關的環境變量
$PWD:當前工作目錄
$OLDPWD:上一次的工作目錄
示例:
[root@localhost /]# cd /etc/sysconfig/
[root@localhost sysconfig]#
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是目錄文件:分別複製每個文件至目標目錄中,並保持原名;
常用選項:
-i:交互式複製,即覆蓋之前提醒用戶確認;
-f:強制覆蓋目標文件;
-r, -R:遞歸複製目錄;
-d:複製符號鏈接文件本身,而非其指向的源文件;
-a:-dR --preserve=all, archive,用於實現歸檔;
--preserv=
mode:權限
ownership:屬主和屬組
timestamps: 時間戳
context:安全標籤
xattr:擴展屬性
links:符號鏈接
all:上述所有屬性
示例:
[root@localhost sysconfig]# cp -r /tmp/mytest1 /tmp/null
[root@localhost sysconfig]# ls -R /tmp/null
/tmp/null:
mytest1 pki
/tmp/null/mytest1:
pki
/tmp/null/mytest1/pki:
ca-trust
。。。略 。。。
mv:移動文件或目錄
mv [OPTION]... [-T] SOURCE DEST
mv [OPTION]... SOURCE... DIRECTORY
mv [OPTION]... -t DIRECTORY SOURCE..
常用選項:
-i:交互式;
-f:force
示例:
[root@localhost sysconfig]# mv -f /tmp/mytest2 /tmp/null
[root@localhost sysconfig]# ls -R /tmp/null/mytest2
/tmp/null/mytest2:
ld.so.conf.d
/tmp/null/mytest2/ld.so.conf.d:
kernel-3.10.0-229.el7.x86_64.conf
pwd:顯示工作目錄
$PWD:當前工作目錄
$OLDPWD:上一次的工作目錄
示例:
[root@localhost sysconfig]# pwd
/etc/sysconfig
rm:刪除文件或目錄
rm [OPTION]... FILE...
常用選項:
-i:interactive
-f:force
-r: recursive
刪除目錄:rm -rf /PATH/TO/DIR
危險操作:rm -rf /*
注意:所有不用的文件建議不要直接刪除,而是移動至某個專用目錄;(模擬回收站)
示例:
rmidr:刪除空目錄
rmdir [OPTION]... DIRECTORY...
-p:刪除某目錄後,如果其父目錄爲空,則一併刪除之;
-v: 顯示過程;
chgrp:改變文件屬主和屬組
chgrp [OPTION]... GROUP FILE...
chgrp [OPTION]... --reference=RFILE FILE...
注意:僅管理員可修改文件的屬主和屬組;
chmod:改變文件訪問權限
chmod [OPTION]... MODE[,MODE]... FILE...
chmod [OPTION]... OCTAL-MODE FILE...
chmod [OPTION]... --reference=RFILE FILE...
三類用戶:
u:屬主
g:屬組
o:其它
a: 所有
(1) chmod [OPTION]... MODE[,MODE]... FILE...
MODE表示法:
賦權表示法:直接操作一類用戶的所有權限位rwx;
u=
g=
o=
a=
授權表示法:直接操作一類用戶的一個權限位r,w,x;
u+, u-
g+, g-
o+, o-
a+, a-
(2) chmod [OPTION]... OCTAL-MODE FILE...
(3) chmod [OPTION]... --reference=RFILE FILE...
選項:
-R, --recursive:遞歸修改
注意:用戶僅能修改屬主爲自己的那些文件的權限;
chown:改變文件的所有者和所屬工作組
chown [OPTION]... [OWNER][:[GROUP]] FILE...
chown [OPTION]... --reference=RFILE FILE...
選項:
-R:遞歸修改
mkdir
mkdir [OPTION]... DIRECTORY...
-p: 自動按需創建父目錄;
-v: verbose,顯示詳細過程;
-m MODE:直接給定權限;
注意:路徑基名方爲命令的作用對象;基名之前的路徑必須得存在;
whereis
whereis - locate the binary, source, and manual page files for a command
whereis [options] name...
-b: 僅搜索二進制程序路徑;
-m:僅搜索使用手冊文件路徑;
which
which - shows the full path of (shell) commands
which [options] programname [...]
--skip-alias:忽略別名
file
touch
touch - change file timestamps
touch [OPTION]... FILE...
-c: 指定的文件路徑不存在時不予創建;
-a: 僅修改access time;
-m:僅修改modify time;
-t STAMP
[[CC]YY]MMDDhhmm[.ss]
2、bash的工作特性之命令執行狀態返回值和命令行展開所涉及的內容及其示例演示。
bash的基礎特性:命令的執行狀態結果
命令執行的狀態結果:
bash通過狀態返回值來輸出此結果:
成功:0
失敗:1-255
命令執行完成之後,其狀態返回值保存於bash的特殊變量$?中;
命令正常執行時,有的還會有命令返回值:
根據命令及其功能不同,結果各不相同;
引用命令的執行結果:
$(COMMAND)
或`COMMAND`
bash的基礎特性之:命令行展開
~:自動展開爲用戶的家目錄,或指定的用戶的家目錄;
{}:可承載一個以逗號分隔的路徑列表,並能夠將其展開爲多個路徑;
例如:/tmp/{a,b} 相當於 /tmp/a /tmp/b
3、請使用命令行展開功能來完成以下練習:
(1)、創建/tmp目錄下的:a_c, a_d, b_c, b_d
~]# mkdir /tmp/{a_{c,d},b_{c,d}}
(2)、創建/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
命令如下:
~]# mkdir -pv /tmp/mylinux/{bin,dev,lib64,proc,sbin,sys,tmp,boot/groub,etc/{rc.d/initd,sysconfig/network-scripts},lib/modules,usr/local/{bin.sbin},var/{lock,log,run}}
4、文件的元數據信息有哪些,分別表示什麼含義,如何查看?如何修改文件的時間戳信息。
文件:兩類數據
元數據:metadata(文件基本信息,大小、創建時間、最後一次修改時間等等)
數據: 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
touch命令:
touch - change file timestamps
touch [OPTION]... FILE...
-c: 指定的文件路徑不存在時不予創建;
-a: 僅修改access time;
-m:僅修改modify time;
-t STAMP
[[CC]YY]MMDDhhmm[.ss]
5、如何定義一個命令的別名,如何在命令中引用另一個命令的執行結果?
type COMMAND:
內部:builtin
外部:顯示爲命令文件路徑;
注意:命令可以有別名;別名可以與原名相同,此時原名被隱藏;此時如果要運行原命令,則使用\COMMAND;
命令別名:
獲取所有可用別名的定義:
~]# alias
定義別名:
~]# alias NAME='COMMAND'
注意:僅對當前shell進程有效
撤銷別名:
~]# unalias NAME
6、顯示/var目錄下所有以l開頭,以一個小寫字母結尾,且中間至少出現一位數字(可以有其它字符)的文件或目錄。
~]#ls -d /var/l?[[:lower:]]
7、顯示/etc目錄下,以任意一個數字開頭,且以非數字結尾的文件或目錄。
~]#ls -d /etc/[0-9]*[^0-9]
8、顯示/etc目錄下,以非字母開頭,後面跟了一個字母以及其它任意長度任意字符的文件或目錄。
~]#ls -d /etc/[^a-z][a-z]*
9、在/tmp目錄下創建以tfile開頭,後跟當前日期和時間的文件,文件名形如:tfile-2016-05-27-09-32-22。
~]# touch tfile-$(date +%Y-%m-%d-%H-%M-%S)
10、複製/etc目錄下所有以p開頭,以非數字結尾的文件或目錄到/tmp/mytest1目錄中。
~]# mkdir /tmp/mytest1
~]# cp -a /etc/p*[^0-9] /tmp/mytest1
11、複製/etc目錄下所有以.d結尾的文件或目錄至/tmp/mytest2目錄中。
~]# mkdir /tmp/mytest2
~]# cp -a /etc/*.d /tmp/mytest2
12、複製/etc/目錄下所有以l或m或n開頭,以.conf結尾的文件至/tmp/mytest3目錄中。
~]# mkdir /tmp/mytest2
~]# cp -a /etc/[lmn]*.conf /tmp/mytest3