溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux常用命令chmod怎么用

發(fā)布時(shí)間:2022-02-16 11:53:45 來(lái)源:億速云 閱讀:149 作者:小新 欄目:開(kāi)發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)Linux常用命令chmod怎么用的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。

Linux常用命令chmod(英文全拼:change mode)命令是控制用戶對(duì)文件的權(quán)限的命令,Linux/Unix 的文件調(diào)用權(quán)限分為三級(jí) : 文件所有者(Owner)、用戶組(Group)、其它用戶(Other Users)。

Linux常用命令chmod怎么用

語(yǔ)法

 chmod [-cfvR] [--help] [--version] mode file...

參數(shù)說(shuō)明

mode : 權(quán)限設(shè)定字串,格式如下 :

 [ugoa...][[+-=][rwxX]...][,...]

其中:

  • u 表示該文件的擁有者,g 表示與該文件的擁有者屬于同一個(gè)群體(group)者,o 表示其他以外的人,a 表示這三者皆是。

  • + 表示增加權(quán)限、- 表示取消權(quán)限、= 表示唯一設(shè)定權(quán)限。

  • r 表示可讀取,w 表示可寫(xiě)入,x 表示可執(zhí)行,X 表示只有當(dāng)該文件是個(gè)子目錄或者該文件已經(jīng)被設(shè)定過(guò)為可執(zhí)行。

其他參數(shù)說(shuō)明:

  • -c : 若該文件權(quán)限確實(shí)已經(jīng)更改,才顯示其更改動(dòng)作

  • -f : 若該文件權(quán)限無(wú)法被更改也不要顯示錯(cuò)誤訊息

  • -v : 顯示權(quán)限變更的詳細(xì)資料

  • -R : 對(duì)目前目錄下的所有文件與子目錄進(jìn)行相同的權(quán)限變更(即以遞歸的方式逐個(gè)變更)

  • –help : 顯示輔助說(shuō)明

  • –version : 顯示版本

符號(hào)模式

使用符號(hào)模式可以設(shè)置多個(gè)項(xiàng)目:who(用戶類(lèi)型),operator(操作符)和 permission(權(quán)限),每個(gè)項(xiàng)目的設(shè)置可以用逗號(hào)隔開(kāi)。 命令 chmod 將修改 who 指定的用戶類(lèi)型對(duì)文件的訪問(wèn)權(quán)限,用戶類(lèi)型由一個(gè)或者多個(gè)字母在 who 的位置來(lái)說(shuō)明,如 who 的符號(hào)模式表所示:

who用戶類(lèi)型說(shuō)明
uuser文件所有者
ggroup文件所有者所在組
oothers所有其他用戶
aall所用用戶, 相當(dāng)于 ugo

operator 的符號(hào)模式表:

Operator說(shuō)明
+為指定的用戶類(lèi)型增加權(quán)限
-去除指定用戶類(lèi)型的權(quán)限
=設(shè)置指定用戶權(quán)限的設(shè)置,即將用戶類(lèi)型的所有權(quán)限重新設(shè)置

permission 的符號(hào)模式表:

模式名字說(shuō)明
r設(shè)置為可讀權(quán)限
w寫(xiě)設(shè)置為可寫(xiě)權(quán)限
x執(zhí)行權(quán)限設(shè)置為可執(zhí)行權(quán)限
X特殊執(zhí)行權(quán)限只有當(dāng)文件為目錄文件,或者其他類(lèi)型的用戶有可執(zhí)行權(quán)限時(shí),才將文件權(quán)限設(shè)置可執(zhí)行
ssetuid/gid當(dāng)文件被執(zhí)行時(shí),根據(jù)who參數(shù)指定的用戶類(lèi)型設(shè)置文件的setuid或者setgid權(quán)限
t粘貼位設(shè)置粘貼位,只有超級(jí)用戶可以設(shè)置該位,只有文件所有者u可以使用該位

八進(jìn)制語(yǔ)法

chmod命令可以使用八進(jìn)制數(shù)來(lái)指定權(quán)限。文件或目錄的權(quán)限位是由9個(gè)權(quán)限位來(lái)控制,每三位為一組,它們分別是文件所有者(User)的讀、寫(xiě)、執(zhí)行,用戶組(Group)的讀、寫(xiě)、執(zhí)行以及其它用戶(Other)的讀、寫(xiě)、執(zhí)行。歷史上,文件權(quán)限被放在一個(gè)比特掩碼中,掩碼中指定的比特位設(shè)為1,用來(lái)說(shuō)明一個(gè)類(lèi)具有相應(yīng)的優(yōu)先級(jí)。

#權(quán)限rwx二進(jìn)制
7讀 + 寫(xiě) + 執(zhí)行rwx111
6讀 + 寫(xiě)rw-110
5讀 + 執(zhí)行r-x101
4只讀r–100
3寫(xiě) + 執(zhí)行-wx011
2只寫(xiě)-w-010
1只執(zhí)行–x001
0無(wú)—000

例如, 765 將這樣解釋?zhuān)?/p>

  • 所有者的權(quán)限用數(shù)字表達(dá):屬主的那三個(gè)權(quán)限位的數(shù)字加起來(lái)的總和。如 rwx ,也就是 4+2+1 ,應(yīng)該是 7。

  • 用戶組的權(quán)限用數(shù)字表達(dá):屬組的那個(gè)權(quán)限位數(shù)字的相加的總和。如 rw- ,也就是 4+2+0 ,應(yīng)該是 6。

  • 其它用戶的權(quán)限數(shù)字表達(dá):其它用戶權(quán)限位的數(shù)字相加的總和。如 r-x ,也就是 4+0+1 ,應(yīng)該是 5。

實(shí)例

將文件 file1.txt 設(shè)為所有人皆可讀取 :

 chmod ugo+r file1.txt

將文件 file1.txt 設(shè)為所有人皆可讀取 :

 chmod a+r file1.txt

將文件 file1.txt 與 file2.txt 設(shè)為該文件擁有者,與其所屬同一個(gè)群體者可寫(xiě)入,但其他以外的人則不可寫(xiě)入 :

 chmod ug+w,o-w file1.txt file2.txt

為 ex1.py 文件擁有者增加可執(zhí)行權(quán)限:

 chmod u+x ex1.py

將目前目錄下的所有文件與子目錄皆設(shè)為任何人可讀取 :

 chmod -R a+r *

此外chmod也可以用數(shù)字來(lái)表示權(quán)限如 :

 chmod 777 file

語(yǔ)法為:

 chmod abc file

其中a,b,c各為一個(gè)數(shù)字,分別表示User、Group、及Other的權(quán)限。

r=4,w=2,x=1
  • 若要 rwx 屬性則 4+2+1=7;

  • 若要 rw- 屬性則 4+2=6;

  • 若要 r-x 屬性則 4+1=5。

 chmod a=rwx file

 chmod 777 file

效果相同

 chmod ug=rwx,o=x file

 chmod 771 file

效果相同

若用 chmod 4755 filename 可使此程序具有 root 的權(quán)限。

更多說(shuō)明

命令說(shuō)明
chmod a+r *file*給file的所有用戶增加讀權(quán)限
chmod a-x *file*刪除file的所有用戶的執(zhí)行權(quán)限
chmod a+rw *file*給file的所有用戶增加讀寫(xiě)權(quán)限
chmod +rwx *file*給file的所有用戶增加讀寫(xiě)執(zhí)行權(quán)限
chmod u=rw,go= *file*對(duì)file的所有者設(shè)置讀寫(xiě)權(quán)限,清空該用戶組和其他用戶對(duì)file的所有權(quán)限(空格代表無(wú)權(quán)限)
chmod -R u+r,go-r *docs*對(duì)目錄docs和其子目錄層次結(jié)構(gòu)中的所有文件給用戶增加讀權(quán)限,而對(duì)用戶組和其他用戶刪除讀權(quán)限
chmod 664 *file*對(duì)file的所有者和用戶組設(shè)置讀寫(xiě)權(quán)限, 為其其他用戶設(shè)置讀權(quán)限
chmod 0755 *file*相當(dāng)于u=rwx (4+2+1),go=rx (4+1 & 4+1)。0 沒(méi)有特殊模式。
chmod 4755 *file*4設(shè)置了設(shè)置用戶ID位,剩下的相當(dāng)于 u=rwx (4+2+1),go=rx (4+1 & 4+1)。
find path/ -type d -exec chmod a-x {} \;刪除可執(zhí)行權(quán)限對(duì)path/以及其所有的目錄(不包括文件)的所有用戶,使用’-type f’匹配文件
find path/ -type d -exec chmod a+x {} \;允許所有用戶瀏覽或通過(guò)目錄path/

感謝各位的閱讀!關(guān)于“Linux常用命令chmod怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI