chgrp :改變文件所屬群組
chown :改變文件擁有者
chmod :改變文件的權限, SUID, SGID, SBIT等等的特性
chgrp:
改變一個文件的群組真是很簡單的,直接以chgrp來改變即可,咦!這個指令就是change group的縮寫嘛!這樣就很好記了吧! _。不過,請記得,要被改變的組名必須要在/etc/group文件內(nèi)存在才行,否則就會顯示錯誤!
假設你是以root的身份登入Linux系統(tǒng)的,那么在你的家目錄內(nèi)有一個install.log的文件, 如何將該文件的群組改變一下呢?假設你已經(jīng)知道在/etc/group里面已經(jīng)存在一個名為users的群組, 但是testing這個群組名字就不存在/etc/group當中了,此時改變?nèi)航M成為users與testing分別會有什么現(xiàn)象發(fā)生呢?
[root@www ~]# chgrp [-R] dirname/filename ...
選項與參數(shù):
-R : 進行遞歸(recursive)的持續(xù)變更,亦即連同次目錄下的所有文件、目錄
都更新成為這個群組之意。常常用在變更某一目錄內(nèi)所有的文件之情況。
范例:
[root@www ~]# chgrp users install.log
[root@www ~]# ls -l
-rw-r--r-- 1 root users 68495 Jun 25 08:53 install.log
[root@www ~]# chgrp testing install.log
chgrp: invalid group name `testing' <== 發(fā)生錯誤訊息啰~找不到這個群組名~
發(fā)現(xiàn)了嗎?文件的群組被改成users了,但是要改成testing的時候, 就會發(fā)生錯誤~注意喔!發(fā)生錯誤訊息還是要努力的查一查錯誤訊息的內(nèi)容才好! 將他英文翻譯成為中文,就知道問題出在哪里了。
chown:
如何改變一個文件的擁有者呢?很簡單呀!既然改變?nèi)航M是change group,那么改變擁有者就是change owner啰!BINGO!那就是chown這個指令的用途,要注意的是, 用戶必須是已經(jīng)存在系統(tǒng)中的賬號,也就是在/etc/passwd 這個文件中有紀錄的用戶名稱才能改變。
chown的用途還滿多的,他還可以順便直接修改群組的名稱呢!此外,如果要連目錄下的所有次目錄或文件同時更改文件擁有者的話,直接加上 -R 的選項即可!我們來看看語法與范例:
[root@www ~]# chown [-R] 賬號名稱 文件或目錄
[root@www ~]# chown [-R] 賬號名稱:組名 文件或目錄
選項與參數(shù):
-R : 進行遞歸(recursive)的持續(xù)變更,亦即連同次目錄下的所有文件都變更
范例:將install.log的擁有者改為bin這個賬號:
[root@www ~]# chown bin install.log
[root@www ~]# ls -l
-rw-r--r-- 1 bin users 68495 Jun 25 08:53 install.log
范例:將install.log的擁有者與群組改回為root:
[root@www ~]# chown root:root install.log
[root@www ~]# ls -l
-rw-r--r-- 1 root root 68495 Jun 25 08:53 install.log
知道如何改變文件的群組與擁有者了,那么什么時候要使用chown或chgrp呢?或許你會覺得奇怪吧? 是的,確實有時候需要變更文件的擁有者的,最常見的例子就是在復制文件給你之外的其他人時, 我們使用最簡單的cp指令來說明好了:
[root@www ~]# cp 來源文件 目標文件
假設你今天要將.bashrc這個文件拷貝成為.bashrc_test檔名,且是要給bin這個人,你可以這樣做:
[root@www ~]# cp .bashrc .bashrc_test
[root@www ~]# ls -al .bashrc*
-rw-r--r-- 1 root root 395 Jul 4 11:45 .bashrc
-rw-r--r-- 1 root root 395 Jul 13 11:31 .bashrc_test <==新文件的屬性沒變
由于復制行為(cp)會復制執(zhí)行者的屬性與權限,所以!怎么辦?.bashrc_test還是屬于root所擁有, 如此一來,即使你將文件拿給bin這個使用者了,那他仍然無法修改的(看屬性/權限就知道了吧), 所以你就必須要將這個文件的擁有者與群組修改一下啰!知道如何修改了吧?
chmod:
文件權限的改變使用的是chmod這個指令,但是,權限的設定方法有兩種, 分別可以使用數(shù)字或者是符號來進行權限的變更。我們就來談一談:
數(shù)字類型改變文件權限Linux文件的基本權限就有九個,分別是owner/group/others三種身份各有自己的read/write/execute權限, 先復習一下剛剛上面提到的數(shù)據(jù):文件的權限字符為:『-rwxrwxrwx』, 這九個權限是三個三個一組的!其中,我們可以使用數(shù)字來代表各個權限,各權限的分數(shù)對照表如下:r:4w:2x:1
每種身份(owner/group/others)各自的三個權限(r/w/x)分數(shù)是需要累加的,例如當權限為: [-rwxrwx---] 分數(shù)則是:owner = rwx = 4+2+1 = 7group = rwx = 4+2+1 = 7others= --- = 0+0+0 = 0
所以等一下我們設定權限的變更時,該文件的權限數(shù)字就是770啦!變更權限的指令chmod的語法是這樣的:[root@www ~]# chmod [-R] xyz 文件或目錄選項與參數(shù):xyz : 就是剛剛提到的數(shù)字類型的權限屬性,為 rwx 屬性數(shù)值的相加。-R : 進行遞歸(recursive)的持續(xù)變更,亦即連同次目錄下的所有文件都會變更
舉例來說,如果要將.bashrc這個文件所有的權限都設定啟用,那么就下達: [root@www ~]# ls -al .bashrc-rw-r--r-- 1 root root 395 Jul 4 11:45 .bashrc[root@www ~]# chmod 777 .bashrc[root@www ~]# ls -al .bashrc-rwxrwxrwx 1 root root 395 Jul 4 11:45 .bashrc
那如果要將權限變成『 -rwxr-xr-- 』呢?那么權限的分數(shù)就成為 [4+2+1][4+0+1][4+0+0]=754 啰!所以你需要下達『 chmod 754 filename』。 另外,在實際的系統(tǒng)運作中最常發(fā)生的一個問題就是,常常我們以vim編輯一個shell的文字批處理文件后,他的權限通常是 -rw-rw-r-- 也就是664, 如果要將該文件變成可執(zhí)行文件,并且不要讓其他人修改此一文件的話, 那么就需要-rwxr-xr-x這樣的權限,此時就得要下達:『 chmod 755 test.sh 』的指令啰!另外,如果有些文件你不希望被其他人看到,那么應該將文件的權限設定為例如:『-rwxr-----』,那就下達『 chmod 740 filename 』吧! 例題:將剛剛你的.bashrc這個文件的權限修改回-rw-r--r--的情況吧!
答:-rw-r--r--的分數(shù)是644,所以指令為:chmod 644 .bashrc
符號類型改變文件權限還有一個改變權限的方法呦!從之前的介紹中我們可以發(fā)現(xiàn),基本上就九個權限分別是(1)user (2)group (3)others三種身份啦!那么我們就可以藉由u, g, o來代表三種身份的權限!此外, a 則代表 all 亦即全部的身份!那么讀寫的權限就可以寫成r, w, x!也就是可以使用底下的方式來看:chmod
ugoa
+(加入)-(除去)=(設定)
rwx
文件或目錄
來實作一下吧!假如我們要『設定』一個文件的權限成為『-rwxr-xr-x』時,基本上就是:user (u):具有可讀、可寫、可執(zhí)行的權限;
group 與 others (g/o):具有可讀與執(zhí)行的權限。
所以就是:[root@www ~]# chmod u=rwx,go=rx .bashrc# 注意喔!那個 u=rwx,go=rx 是連在一起的,中間并沒有任何空格![root@www ~]# ls -al .bashrc-rwxr-xr-x 1 root root 395 Jul 4 11:45 .bashrc
那么假如是『 -rwxr-xr-- 』這樣的權限呢?可以使用『 chmod u=rwx,g=rx,o=r filename 』來設定。此外,如果我不知道原先的文件屬性,而我只想要增加.bashrc這個文件的每個人均可寫入的權限, 那么我就可以使用:[root@www ~]# ls -al .bashrc-rwxr-xr-x 1 root root 395 Jul 4 11:45 .bashrc[root@www ~]# chmod a+w .bashrc[root@www ~]# ls -al .bashrc-rwxrwxrwx 1 root root 395 Jul 4 11:45 .bashrc
而如果是要將權限去掉而不更動其他已存在的權限呢?例如要拿掉全部人的可執(zhí)行權限,則:[root@www ~]# chmod a-x .bashrc[root@www ~]# ls -al .bashrc-rw-rw-rw- 1 root root 395 Jul 4 11:45 .bashrc
知道 +, -, = 的不同點了嗎?對啦! + 與 – 的狀態(tài)下,只要是沒有指定到的項目,則該權限『不會被變動』, 例如上面的例子中,由于僅以 – 拿掉 x 則其他兩個保持當時的值不變!多多實作一下,你就會知道如何改變權限啰! 這在某些情況底下很好用的~舉例來說,你想要教一個朋友如何讓一個程序可以擁有執(zhí)行的權限, 但你又不知道該文件原本的權限為何,此時,利用『chmod a+x filename』 ,就可以讓該程序擁有執(zhí)行的權限了。是否很方便?