原創文章,歡迎轉載,轉載請註明出處:http://blog.csdn.net/hust_superman/article/details/23873425
----------------------------------------------------cat命令--------------------------------------
查看一個名爲 TEXT的文字檔內容。
cat TEXT.txt
cat TEXT.txt > TEXT2.txt cat TEXT.txt >> TEXT3.txt
cd,有時也寫作chdir(change directory,改變目錄),是在Unix、Windows和DOS操作系統下用於
改變工作目錄的命令行命令。在Unix的外殼腳本與Windows或DOS的批處理文件中亦可使用。CHDIR()
還是Visual Basic改變工作目錄的一個函數。
目錄是文件系統用於保存文件的邏輯區段,而目錄還可以包含有其他的目錄。通過cd命令,可以前進到子
目錄、後退到父目錄、回到根目錄(Unix下爲“/”,DOS下爲“\”)或者進入到任何給出的目錄中去。假設下面的
這一小段爲Unix文件系統,顯示的是一位用戶的起始目錄(以“~”表示),其中有一個文件(“text.txt”)和三個子目錄。
在類UNIX系統中,用戶從起始目錄(通常簡寫作“~”)看到的文件系統。從起始目錄開始,樹狀圖會延伸出更多的子目錄和/或文件來。
當用戶的當前工作目錄爲起始目錄(“~”)時,首先輸入命令“ls”,然後輸入“cd games”,會產生下列的效果:
me@host:~$ ls workreports games encyclopedia text.txt me@host:~$ cd games me@host:~/games$
該用戶現在的工作目錄即爲“game”目錄。
在DOS中,與之相似的過程(“起始目錄”的概念可能會不適用,這取決於該DOS的版本)會像這樣顯示:
C:\> dir workreports <DIR> Wed Oct 9th 9:01 games <DIR> Tue Oct 8th 14:32 encyclopedia <DIR> Mon Oct 1st 10:05 text txt 1903 Thu Oct10th 12:43 C:\> cd games C:\games>
應注意的一點是,在不同的操作系統中,如果不給出變量會讓cd產生不同的結果。例如,如果在DOS下
不給出變量而執行,會顯示出當前的工作目錄來;而在Unix下不給出變量而執行,則會返回到起始目錄去。
在腳本或批處理內執行的cd,也會產生不同的結果。在DOS中,批處理文件中使用的該命令可以直接改變
調用者的當前目錄;而在Unix下,使用cd命令的腳本則無法改變調用者的當前目錄。這是因爲在Unix下的
腳本通常在子外殼中執行。Unix系統的cd是調用POSIX C的函數chdir()
:即是,當該命令執行時,不會爲
前往另一個目錄而創建一個新的進程,而是由外殼代爲執行這條命令,ls等其他命令也是這種情況。
這是因爲,創建新的進程時,子進程會繼承父進程創建時的目錄。而如果cd命令繼承了父進程的目錄,
則它永遠也不能達到它的目標。
--------------------------------------------------------------chmod---------------------------------------------
chmod 是一條在Unix系統中用於控制用戶對文件的權限的命令(change mode單詞前綴的組合)
和函數。只有文件所有者和超級用戶可以修改文件或目錄的權限。可以使用絕對模式,
符號模式指定文件的權限。
chmod使用語法
$ chmod [options] mode[,mode] file1 [file2 ...]
使用ls命令的查看文件或目錄的屬性
$ ls -l file
符號模式[編輯]
使用符號模式可以設置多個項目:who(用戶類型),operator(操作符)和permission(權限),
每個項目的設置可以用逗號隔開。命令chmod將修改who指定的用戶類型對文件的訪問權限,
用戶類型由一個或者多個字母在who的位置來說明,如who的符號模式表所示:
who | 用戶類型 | 說明 |
---|---|---|
u | user | 文件所有者 |
g | group | 文件所有者所在組 |
o | others | 所有其他用戶 |
a | all | 所用用戶, 相當於 ugo |
operator的符號模式表:
Operator | 說明 |
---|---|
+ | 爲指定的用戶類型增加權限 |
- | 去除指定用戶類型的權限 |
= | 設置指定用戶權限的設置,即將用戶類型的所有權限重新設置 |
permission的符號模式表:
模式 | 名字 | 說明 |
---|---|---|
r | 讀 | 設置爲可讀權限 |
w | 寫 | 設置爲可寫權限 |
x | 執行權限 | 設置爲可執行權限 |
X | 特殊執行權限 | 只有當文件爲目錄文件,或者其他類型的用戶有可執行權限時,纔將文件權限設置可執行 |
s | setuid/gid | 當文件被執行時,根據who參數指定的用戶類型設置文件的setuid或者setgid權限 |
t | 粘貼位 | 設置粘貼位,只有超級用戶可以設置該位,只有文件所有者u可以使用該位 |
符號模式實例[編輯]
對目錄的所有者u和關聯組g增加讀r和寫w權限:
$ chmod ug+rw mydir $ ls -ld mydir drw-rw---- 2 unixguy uguys 96 Dec 8 12:53 mydir
對文件的所有用戶ugo刪除寫w權限:
$ chmod a-w myfile $ ls -l myfile -r-xr-xr-x 2 unixguy uguys 96 Dec 8 12:53 myfile
對mydir的所有者u和關聯組g設置成讀r和可執行x權限:
$ chmod ug=rx mydir $ ls -ld mydir dr-xr-x--- 2 unixguy uguys 96 Dec 8 12:53 mydir
命令使用實例[編輯]
命令 | 說明 |
---|---|
chmod a+r file | 增加讀權限對file的所有用戶 |
chmod a-x file | 刪除執行權限對file的所有用戶 |
chmod a+rw file | 增加讀寫權限對file的所有用戶 |
chmod +rwx file | 增加讀寫執行權限對file的所有用戶 |
chmod u=rw,go= file | 設置讀寫權限對file的所有者,清空所有權限對file的用戶組和其他用戶 |
chmod -R u+r,go-r docs | 對目錄docs和其子目錄層次結構中的所有文件增加所有用戶的讀權限,而對用戶組和其他用戶刪除讀權限 |
chmod 664 file | 設置讀寫權限對file的所有者和用戶組, 爲其其他用戶設置讀權限 |
chmod 0755 file | 相當於u=rwx (4+2+1),go=rx (4+1 & 4+1)。0 沒有特殊模式。 |
chmod 4755 file | 4設置了設置用戶ID位,剩下的相當於 u=rwx (4+2+1),go=rx (4+1 & 4+1)。 |
find path/ -type d -exec chmod a-x {} \; | 刪除可執行權限對path/以及其所有的目錄(不包括文件)的所有用戶,使用‘-type f'匹配文件 |
find path/ -type d -exec chmod a+x {} \; | 允許所有用戶瀏覽或通過目錄path/ |
八進制語法[編輯]
chmod命令可以使用八進制數來指定權限。文件或目錄的權限位是由9個權限位來控制,每三位爲一組,它們分別是文件所有者(user)
的讀、寫、執行,用戶組(group)的讀、寫、執行以及(other)其它用戶的讀、寫、執行。歷史上,文件權限被放在一個比特掩碼中,
掩碼中指定的比特位設爲1,用來說明一個類具有相應的優先級。
chmod的八進制語法的數字說明;
r 4
w 2
x 1
- 0
所有者的權限用數字表達:屬主的那三個權限位的數字加起來的總和。如rwx ,也就是4+2+1 ,應該是7。
用戶組的權限用數字表達:屬組的那個權限位數字的相加的總和。如rw- ,也就是4+2+0 ,應該是6。
其它用戶的權限數字表達:其它用戶權限位的數字相加的總和。如r-x ,也就是4+0+1 ,應該是5。
例如修改文件myfile的權限
$ chmod 664 myfile $ ls -l myfile -rw-rw-r-- 1 57 Jul 3 10:13 myfile